Haxe VS Wasm benchmarks

Current benchmark data was generated on Sun Dec 01 2024, 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
haxe 1.hx 1329ms 25ms 145.7MB 1547ms 63ms haxe/cpp 4.3.6
wasm 5.rs 1531ms 12ms 55.1MB 1500ms 13ms wasmer/llvm 5.0.2
wasm 4.rs 1599ms 10.0ms 54.8MB 1570ms 17ms wasmer/llvm 5.0.2
wasm 3.rs 1644ms 39ms 71.3MB 1600ms 27ms wasmer/llvm 5.0.2
wasm 5.rs 1750ms 25ms 34.8MB 1723ms 10ms wasmtime 27.0.0
wasm 4.rs 1794ms 30ms 34.9MB 1777ms 3ms wasmtime 27.0.0
wasm 3.rs 1860ms 47ms 52.9MB 1830ms 17ms wasmtime 27.0.0
haxe 2.hx 4475ms 79ms 497.1MB 5153ms 213ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 50.6MB 5560ms 417ms haxe/hl/c 4.3.6
haxe 2.hx timeout 0.0ms 85.0MB 5067ms 693ms haxe/hl/c 4.3.6
haxe 1.hx timeout 0.0ms 52.4MB 7860ms 440ms haxe/hl/jit 1.14.0
haxe 2.hx timeout 0.0ms 132.9MB 7410ms 773ms haxe/hl/jit 1.14.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 93ms 1.2ms 27.6MB 90ms 7ms haxe/cpp 4.3.6
wasm 5.rs 152ms 0.8ms 41.0MB 140ms 0ms wasmer/llvm 5.0.2
wasm 4.rs 161ms 3.1ms 41.0MB 143ms 3ms wasmer/llvm 5.0.2
wasm 3.rs 165ms 6.6ms 42.9MB 143ms 7ms wasmer/llvm 5.0.2
wasm 4.rs 171ms 1.2ms 21.0MB 157ms 3ms wasmtime 27.0.0
wasm 3.rs 174ms 3.1ms 22.9MB 157ms 3ms wasmtime 27.0.0
wasm 5.rs 181ms 18ms 22.9MB 163ms 0ms wasmtime 27.0.0
haxe 2.hx 405ms 19ms 60.3MB 440ms 27ms haxe/cpp 4.3.6
haxe 1.hx 637ms 9.9ms 10.7MB 600ms 57ms haxe/hl/c 4.3.6
haxe 1.hx 673ms 7.3ms 13.4MB 730ms 57ms haxe/hl/jit 1.14.0
haxe 2.hx 925ms 7.0ms 15.5MB 787ms 183ms haxe/hl/c 4.3.6
haxe 2.hx 1253ms 56ms 27.2MB 1317ms 183ms haxe/hl/jit 1.14.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 230ms 2.2ms 19.0MB 213ms 0ms wasmtime 27.0.0
wasm 1.rs 331ms 4.4ms 37.5MB 233ms 70ms wasmer/llvm 5.0.2
haxe 1.hx 2465ms 27ms 27.4MB 2353ms 250ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 5.4MB 4233ms 970ms haxe/hl/c 4.3.6
haxe 1.hx timeout 0.0ms 5.7MB 4290ms 933ms haxe/hl/jit 1.14.0

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 34ms 5.0ms 19.0MB 20ms 3ms wasmtime 27.0.0
wasm 1.rs 45ms 0.8ms 37.5MB 23ms 3ms wasmer/llvm 5.0.2
haxe 1.hx 261ms 3.2ms 27.6MB 223ms 37ms haxe/cpp 4.3.6
haxe 1.hx 652ms 1.7ms 5.4MB 547ms 120ms haxe/hl/c 4.3.6
haxe 1.hx 693ms 3.7ms 5.7MB 593ms 120ms 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.3ms 4.7MB 0ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 2.3ms 0.2ms 4.4MB 0ms 0ms haxe/cpp 4.3.6
haxe 1.hx 4.1ms 0.3ms 4.7MB 0ms 0ms haxe/hl/jit 1.14.0
wasm 1.rs 7.4ms 0.3ms 21.1MB 0ms 0ms wasmtime 27.0.0
wasm 1.rs 12ms 0.4ms 38.6MB 0ms 0ms wasmer/llvm 5.0.2

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 79ms 1.1ms 20.7MB 60ms 0ms wasmtime 27.0.0
wasm 1.rs 80ms 0.5ms 37.2MB 63ms 0ms wasmer/llvm 5.0.2
haxe 1.hx 135ms 3.7ms 20.4MB 123ms 3ms haxe/cpp 4.3.6
haxe 1.hx 136ms 1.5ms 5.0MB 130ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 159ms 3.9ms 5.8MB 143ms 3ms haxe/hl/jit 1.14.0

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 220ms 0.7ms 37.4MB 207ms 3ms wasmer/llvm 5.0.2
wasm 1.rs 224ms 4.2ms 19.1MB 210ms 0ms wasmtime 27.0.0
haxe 1.hx 378ms 2.7ms 25.5MB 360ms 7ms haxe/cpp 4.3.6
haxe 1.hx 396ms 2.4ms 5.1MB 383ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 458ms 2.3ms 5.8MB 447ms 3ms haxe/hl/jit 1.14.0

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 46ms 0.7ms 19.2MB 37ms 0ms wasmtime 27.0.0
wasm 1.rs 49ms 1.3ms 38.5MB 37ms 0ms wasmer/llvm 5.0.2
haxe 1.hx 62ms 0.1ms 12.4MB 50ms 0ms haxe/cpp 4.3.6
haxe 1.hx 67ms 0.4ms 5.0MB 60ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 79ms 0.1ms 5.7MB 67ms 0ms haxe/hl/jit 1.14.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 774ms 5.0ms 61.2MB 737ms 23ms wasmer/llvm 5.0.2
wasm 1.rs 868ms 25ms 42.9MB 840ms 13ms wasmtime 27.0.0
haxe 1.hx 926ms 34ms 96.9MB 1033ms 43ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 34.5MB 4910ms 500ms haxe/hl/c 4.3.6
haxe 1.hx timeout 0.0ms 57.0MB 5923ms 507ms haxe/hl/jit 1.14.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 173ms 2.0ms 28.6MB 173ms 7ms haxe/cpp 4.3.6
wasm 1.rs 175ms 0.7ms 45.1MB 153ms 10ms wasmer/llvm 5.0.2
wasm 1.rs 192ms 10ms 24.9MB 180ms 3ms wasmtime 27.0.0
haxe 1.hx 1302ms 9.8ms 12.7MB 1247ms 133ms haxe/hl/c 4.3.6
haxe 1.hx 1487ms 13ms 22.3MB 1537ms 123ms haxe/hl/jit 1.14.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 343ms 1.8ms 37.1MB 323ms 3ms wasmer/llvm 5.0.2
wasm 1.rs 406ms 1.4ms 20.8MB 390ms 0ms wasmtime 27.0.0
wasm 2.rs 552ms 37ms 39.3MB 540ms 0ms wasmer/llvm 5.0.2
wasm 2.rs 576ms 0.6ms 20.8MB 560ms 0ms wasmtime 27.0.0
haxe 2.hx 867ms 20ms 5.1MB 860ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 1053ms 7.5ms 5.0MB 1040ms 0ms haxe/hl/c 4.3.6
haxe 3.hx 1390ms 21ms 25.6MB 1597ms 40ms haxe/cpp 4.3.6
haxe 2.hx 2402ms 3.1ms 5.7MB 2387ms 0ms haxe/hl/jit 1.14.0
haxe 1.hx 2451ms 7.8ms 5.7MB 2433ms 0ms haxe/hl/jit 1.14.0
haxe 1.hx timeout 0.0ms 4.4MB 4990ms 0ms haxe/cpp 4.3.6
haxe 2.hx timeout 0.0ms 4.4MB 4990ms 0ms haxe/cpp 4.3.6
haxe 3.hx timeout 0.0ms 5.2MB 3863ms 1640ms haxe/hl/c 4.3.6
haxe 3.hx timeout 0.0ms 5.9MB 4157ms 1303ms haxe/hl/jit 1.14.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 47ms 0.8ms 38.4MB 30ms 3ms wasmer/llvm 5.0.2
wasm 1.rs 49ms 0.5ms 20.8MB 33ms 3ms wasmtime 27.0.0
wasm 2.rs 66ms 0.8ms 20.8MB 50ms 3ms wasmtime 27.0.0
wasm 2.rs 67ms 3.4ms 37.4MB 50ms 7ms wasmer/llvm 5.0.2
haxe 2.hx 89ms 2.0ms 5.0MB 80ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 110ms 3.1ms 5.0MB 100ms 0ms haxe/hl/c 4.3.6
haxe 3.hx 158ms 1.7ms 25.6MB 163ms 7ms haxe/cpp 4.3.6
haxe 2.hx 250ms 2.1ms 5.7MB 240ms 0ms haxe/hl/jit 1.14.0
haxe 1.hx 250ms 1.7ms 5.7MB 237ms 0ms haxe/hl/jit 1.14.0
haxe 3.hx 665ms 0.8ms 5.1MB 527ms 193ms haxe/hl/c 4.3.6
haxe 2.hx 671ms 3.3ms 4.4MB 657ms 0ms haxe/cpp 4.3.6
haxe 3.hx 773ms 2.5ms 5.8MB 633ms 197ms haxe/hl/jit 1.14.0
haxe 1.hx 807ms 5.6ms 4.4MB 797ms 0ms haxe/cpp 4.3.6

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 2.rs 3587ms 3.9ms 37.2MB 3573ms 3ms wasmer/llvm 5.0.2
wasm 2.rs 3589ms 8.6ms 18.9MB 3573ms 0ms wasmtime 27.0.0
wasm 7.rs 3597ms 1.9ms 38.9MB 3580ms 3ms wasmer/llvm 5.0.2
haxe 1.hx 3912ms 9.7ms 5.2MB 3900ms 0ms haxe/hl/c 4.3.6
wasm 7.rs 4874ms 3.3ms 20.7MB 4857ms 0ms wasmtime 27.0.0
haxe 1.hx timeout 0.0ms 6.9MB 4980ms 3ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 5.8MB 4983ms 0ms haxe/hl/jit 1.14.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 2.rs 906ms 2.5ms 18.7MB 890ms 0ms wasmtime 27.0.0
wasm 2.rs 909ms 1.3ms 38.9MB 893ms 0ms wasmer/llvm 5.0.2
wasm 7.rs 909ms 0.8ms 39.0MB 893ms 0ms wasmer/llvm 5.0.2
haxe 1.hx 986ms 2.8ms 5.1MB 973ms 0ms haxe/hl/c 4.3.6
wasm 7.rs 1233ms 11ms 18.7MB 1220ms 0ms wasmtime 27.0.0
haxe 1.hx 2391ms 1.0ms 6.6MB 2377ms 0ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 5.8MB 4980ms 7ms haxe/hl/jit 1.14.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 2.rs 234ms 2.2ms 18.5MB 220ms 0ms wasmtime 27.0.0
wasm 2.rs 238ms 1.1ms 38.9MB 227ms 0ms wasmer/llvm 5.0.2
wasm 7.rs 239ms 1.1ms 37.2MB 223ms 0ms wasmer/llvm 5.0.2
haxe 1.hx 251ms 2.6ms 5.0MB 243ms 0ms haxe/hl/c 4.3.6
wasm 7.rs 321ms 11ms 18.8MB 303ms 0ms wasmtime 27.0.0
haxe 1.hx 600ms 0.8ms 5.4MB 583ms 0ms haxe/cpp 4.3.6
haxe 1.hx 2304ms 7.8ms 5.7MB 2287ms 0ms haxe/hl/jit 1.14.0