Haxe VS Python benchmarks

Current benchmark data was generated on Wed Jan 22 2025, 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
python 1.py 1189ms 1.9ms 95.8MB 1113ms 57ms pypy 3.10.14
haxe 1.hx 1321ms 20ms 145.9MB 1507ms 70ms haxe/cpp 4.3.6
haxe 2.hx 4434ms 85ms 495.3MB 5067ms 240ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 50.6MB 5500ms 407ms haxe/hl/c 4.3.6
haxe 2.hx timeout 0.0ms 85.0MB 5020ms 703ms haxe/hl/c 4.3.6
haxe 1.hx timeout 0.0ms 52.4MB 7647ms 430ms haxe/hl/jit 1.14.0
haxe 2.hx timeout 0.0ms 133.0MB 7440ms 810ms haxe/hl/jit 1.14.0
python 1.py timeout 0.0ms 40.9MB 4970ms 17ms cpython 3.13.1
python 1.py timeout 0.0ms 40.6MB 4760ms 227ms pyston 3.8.12

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 94ms 2.6ms 27.5MB 90ms 7ms haxe/cpp 4.3.6
python 1.py 96ms 2.4ms 68.1MB 67ms 20ms pypy 3.10.14
haxe 2.hx 406ms 6.6ms 58.3MB 430ms 37ms haxe/cpp 4.3.6
python 1.py 486ms 19ms 11.9MB 457ms 13ms pyston 3.8.12
haxe 1.hx 633ms 3.4ms 10.8MB 597ms 53ms haxe/hl/c 4.3.6
haxe 1.hx 685ms 25ms 13.2MB 743ms 57ms haxe/hl/jit 1.14.0
python 1.py 705ms 9.2ms 12.6MB 693ms 0ms cpython 3.13.1
haxe 2.hx 927ms 18ms 15.7MB 807ms 160ms haxe/hl/c 4.3.6
haxe 2.hx 1160ms 86ms 27.0MB 1173ms 200ms haxe/hl/jit 1.14.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
python 1.py 1911ms 8.2ms 88.3MB 1857ms 40ms pypy 3.10.14
haxe 1.hx 2444ms 20ms 27.5MB 2297ms 270ms haxe/cpp 4.3.6
python 5-m.py 2495ms 45ms 12.5MB 3553ms 1080ms pyston 3.8.12
python 5-m.py 2855ms 12ms 65.0MB 4090ms 777ms pypy 3.10.14
python 1.py 3021ms 48ms 8.1MB 3007ms 0ms pyston 3.8.12
python 5-m.py 3417ms 98ms 13.9MB 4510ms 963ms cpython 3.13.1
python 1.py 4635ms 124ms 8.6MB 4623ms 0ms cpython 3.13.1
haxe 1.hx timeout 0.0ms 5.3MB 4280ms 930ms haxe/hl/c 4.3.6
haxe 1.hx timeout 0.0ms 5.5MB 4340ms 887ms haxe/hl/jit 1.14.0

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
python 1.py 251ms 0.5ms 63.5MB 217ms 13ms pypy 3.10.14
haxe 1.hx 260ms 0.3ms 27.5MB 220ms 40ms haxe/cpp 4.3.6
python 1.py 311ms 2.8ms 8.1MB 300ms 0ms pyston 3.8.12
python 5-m.py 312ms 2.4ms 12.5MB 397ms 143ms pyston 3.8.12
python 5-m.py 402ms 4.6ms 13.8MB 477ms 150ms cpython 3.13.1
python 1.py 471ms 5.4ms 8.8MB 460ms 0ms cpython 3.13.1
python 5-m.py 544ms 2.1ms 64.9MB 817ms 287ms pypy 3.10.14
haxe 1.hx 653ms 2.7ms 5.4MB 547ms 123ms haxe/hl/c 4.3.6
haxe 1.hx 691ms 7.5ms 5.7MB 580ms 127ms haxe/hl/jit 1.14.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 2.2ms 0.2ms 4.9MB 0ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 2.6ms 0.1ms 4.3MB 0ms 0ms haxe/cpp 4.3.6
haxe 1.hx 3.6ms 0.2ms 4.8MB 0ms 0ms haxe/hl/jit 1.14.0
python 1.py 12ms 1.1ms 7.6MB 0ms 0ms pyston 3.8.12
python 1.py 14ms 1.2ms 8.5MB 10ms 0ms cpython 3.13.1
python 1.py 28ms 0.6ms 51.0MB 10ms 8ms pypy 3.10.14

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 134ms 1.1ms 20.4MB 127ms 0ms haxe/cpp 4.3.6
haxe 1.hx 135ms 0.4ms 5.0MB 127ms 0ms haxe/hl/c 4.3.6
python 2.py 146ms 1.1ms 57.9MB 120ms 13ms pypy 3.10.14
haxe 1.hx 152ms 0.4ms 5.7MB 140ms 0ms haxe/hl/jit 1.14.0
python 1.py 181ms 1.4ms 59.5MB 153ms 10ms pypy 3.10.14
python 1.py 718ms 4.4ms 8.9MB 707ms 0ms pyston 3.8.12
python 2.py 832ms 3.1ms 8.5MB 817ms 0ms pyston 3.8.12
python 1.py 1101ms 2.8ms 9.3MB 1083ms 0ms cpython 3.13.1
python 2.py 1309ms 4.2ms 9.1MB 1297ms 0ms cpython 3.13.1

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
python 2.py 338ms 1.6ms 58.9MB 313ms 7ms pypy 3.10.14
haxe 1.hx 375ms 1.6ms 25.5MB 363ms 7ms haxe/cpp 4.3.6
python 1.py 385ms 6.4ms 60.4MB 353ms 13ms pypy 3.10.14
haxe 1.hx 403ms 6.2ms 5.0MB 393ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 451ms 3.3ms 5.7MB 437ms 0ms haxe/hl/jit 1.14.0
python 1.py 2127ms 17ms 8.9MB 2110ms 0ms pyston 3.8.12
python 2.py 2489ms 22ms 8.5MB 2473ms 0ms pyston 3.8.12
python 1.py 3291ms 15ms 9.3MB 3283ms 0ms cpython 3.13.1
python 2.py 3877ms 18ms 9.0MB 3860ms 0ms cpython 3.13.1

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 64ms 0.5ms 12.4MB 53ms 0ms haxe/cpp 4.3.6
haxe 1.hx 67ms 1.0ms 5.0MB 60ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 78ms 1.0ms 5.7MB 70ms 0ms haxe/hl/jit 1.14.0
python 2.py 106ms 2.6ms 57.8MB 83ms 7ms pypy 3.10.14
python 1.py 122ms 2.7ms 58.5MB 103ms 10ms pypy 3.10.14
python 1.py 345ms 2.4ms 8.5MB 337ms 0ms pyston 3.8.12
python 2.py 390ms 1.7ms 8.1MB 377ms 0ms pyston 3.8.12
python 1.py 523ms 7.0ms 9.0MB 510ms 0ms cpython 3.13.1
python 2.py 622ms 5.9ms 8.6MB 607ms 0ms cpython 3.13.1

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 917ms 8.2ms 96.9MB 1023ms 43ms haxe/cpp 4.3.6
python 1.py 2276ms 12ms 209.9MB 2153ms 103ms pypy 3.10.14
haxe 1.hx timeout 0.0ms 34.5MB 4907ms 497ms haxe/hl/c 4.3.6
haxe 1.hx timeout 0.0ms 59.1MB 6110ms 440ms haxe/hl/jit 1.14.0
python 1.py timeout 0.0ms 93.9MB 4953ms 33ms cpython 3.13.1
python 1.py timeout 0.0ms 130.4MB 4923ms 57ms pyston 3.8.12

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 174ms 3.9ms 28.6MB 173ms 10ms haxe/cpp 4.3.6
python 1.py 389ms 1.4ms 103.6MB 330ms 43ms pypy 3.10.14
haxe 1.hx 1287ms 11ms 12.8MB 1217ms 143ms haxe/hl/c 4.3.6
haxe 1.hx 1312ms 13ms 22.2MB 1310ms 143ms haxe/hl/jit 1.14.0
python 1.py 3030ms 33ms 37.1MB 3000ms 17ms cpython 3.13.1
python 1.py timeout 0.0ms 48.9MB 4937ms 47ms pyston 3.8.12

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 2.hx 852ms 3.3ms 5.1MB 840ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 1050ms 8.1ms 5.0MB 1033ms 0ms haxe/hl/c 4.3.6
python 2.py 1366ms 23ms 59.8MB 1340ms 10ms pypy 3.10.14
haxe 3.hx 1410ms 33ms 25.6MB 1583ms 50ms haxe/cpp 4.3.6
haxe 2.hx 2407ms 6.7ms 5.7MB 2393ms 0ms haxe/hl/jit 1.14.0
haxe 1.hx 2445ms 1.3ms 5.7MB 2430ms 0ms haxe/hl/jit 1.14.0
python 1.py 2633ms 17ms 56.6MB 2607ms 13ms pypy 3.10.14
haxe 1.hx timeout 0.0ms 4.4MB 4987ms 0ms haxe/cpp 4.3.6
haxe 2.hx timeout 0.0ms 4.4MB 4983ms 0ms haxe/cpp 4.3.6
haxe 3.hx timeout 0.0ms 5.2MB 3890ms 1607ms haxe/hl/c 4.3.6
haxe 3.hx timeout 0.0ms 6.0MB 4097ms 1367ms haxe/hl/jit 1.14.0
python 1.py timeout 0.0ms 8.6MB 4983ms 3ms cpython 3.13.1
python 2.py timeout 0.0ms 8.8MB 4990ms 0ms cpython 3.13.1
python 1.py timeout 0.0ms 8.3MB 4983ms 3ms pyston 3.8.12
python 2.py timeout 0.0ms 8.1MB 4987ms 0ms pyston 3.8.12

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 2.hx 91ms 1.0ms 5.0MB 80ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 111ms 2.6ms 5.0MB 100ms 0ms haxe/hl/c 4.3.6
haxe 3.hx 156ms 5.2ms 27.6MB 157ms 7ms haxe/cpp 4.3.6
python 2.py 177ms 2.3ms 57.6MB 150ms 13ms pypy 3.10.14
haxe 2.hx 244ms 0.6ms 5.7MB 230ms 0ms haxe/hl/jit 1.14.0
haxe 1.hx 250ms 1.0ms 5.7MB 240ms 0ms haxe/hl/jit 1.14.0
python 1.py 306ms 2.6ms 56.6MB 280ms 10ms pypy 3.10.14
haxe 2.hx 669ms 3.4ms 4.4MB 660ms 0ms haxe/cpp 4.3.6
haxe 3.hx 679ms 29ms 5.2MB 517ms 213ms haxe/hl/c 4.3.6
haxe 3.hx 773ms 1.8ms 5.8MB 627ms 207ms haxe/hl/jit 1.14.0
haxe 1.hx 823ms 17ms 4.4MB 813ms 0ms haxe/cpp 4.3.6
python 1.py 921ms 5.6ms 8.3MB 907ms 0ms pyston 3.8.12
python 2.py 1297ms 37ms 8.3MB 1283ms 0ms pyston 3.8.12
python 1.py 2982ms 117ms 8.6MB 2973ms 0ms cpython 3.13.1
python 2.py 3119ms 42ms 8.8MB 3103ms 0ms cpython 3.13.1

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 3914ms 2.8ms 5.3MB 3900ms 3ms haxe/hl/c 4.3.6
haxe 1.hx timeout 0.0ms 7.0MB 4990ms 0ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 5.9MB 4983ms 0ms haxe/hl/jit 1.14.0
python 8.py timeout 0.0ms 16.6MB 63ms 0ms cpython 3.13.1
python 8.py timeout 0.0ms 99.4MB 853ms 167ms pypy 3.10.14
python 8.py timeout 0.0ms 18.1MB 77ms 17ms pyston 3.8.12

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 991ms 6.4ms 5.1MB 973ms 3ms haxe/hl/c 4.3.6
haxe 1.hx 2391ms 1.5ms 6.5MB 2380ms 0ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 5.8MB 4983ms 3ms haxe/hl/jit 1.14.0
python 8.py timeout 0.0ms 16.5MB 113ms 17ms cpython 3.13.1
python 8.py timeout 0.0ms 99.1MB 1567ms 470ms pypy 3.10.14
python 8.py timeout 0.0ms 17.6MB 137ms 33ms pyston 3.8.12

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 253ms 2.4ms 5.0MB 243ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 602ms 1.7ms 5.4MB 587ms 0ms haxe/cpp 4.3.6
python 8-m.py 2021ms 18ms 94.9MB 6423ms 333ms pypy 3.10.14
haxe 1.hx 2305ms 4.5ms 5.8MB 2297ms 0ms haxe/hl/jit 1.14.0
python 8.py timeout 0.0ms 16.1MB 233ms 53ms cpython 3.13.1
python 8.py timeout 0.0ms 15.5MB 447ms 113ms pyston 3.8.12