Wasm VS Haxe benchmarks

Current benchmark data was generated on Mon Apr 14 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
haxe 1.hx 1342ms 4.5ms 144.0MB 1543ms 60ms haxe/cpp 4.3.6
wasm 4.rs 1823ms 9.8ms 33.2MB 1800ms 10ms wasmtime 31.0.0
wasm 3.rs 1857ms 49ms 49.2MB 1830ms 17ms wasmtime 31.0.0
wasm 5.rs 1918ms 279ms 33.1MB 1893ms 7ms wasmtime 31.0.0
haxe 2.hx 4432ms 13ms 495.1MB 5033ms 240ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 48.7MB 5777ms 390ms haxe/hl/c 4.3.6
haxe 2.hx timeout 0.0ms 83.0MB 5190ms 670ms haxe/hl/c 4.3.6
haxe 1.hx timeout 0.0ms 50.3MB 7990ms 417ms haxe/hl/jit 1.15.0
haxe 2.hx timeout 0.0ms 130.8MB 7553ms 747ms haxe/hl/jit 1.15.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 94ms 2.8ms 25.6MB 87ms 10ms haxe/cpp 4.3.6
wasm 5.rs 169ms 0.6ms 19.2MB 160ms 0ms wasmtime 31.0.0
wasm 3.rs 181ms 4.3ms 21.2MB 167ms 0ms wasmtime 31.0.0
wasm 4.rs 192ms 31ms 19.1MB 180ms 0ms wasmtime 31.0.0
haxe 2.hx 400ms 3.2ms 58.3MB 433ms 27ms haxe/cpp 4.3.6
haxe 1.hx 686ms 9.9ms 8.8MB 653ms 50ms haxe/hl/c 4.3.6
haxe 1.hx 718ms 17ms 11.2MB 797ms 63ms haxe/hl/jit 1.15.0
haxe 2.hx 1232ms 144ms 13.7MB 1113ms 163ms haxe/hl/c 4.3.6
haxe 2.hx 1251ms 52ms 25.2MB 1313ms 177ms haxe/hl/jit 1.15.0

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 3.rs 1118ms 3.9ms 19.4MB 1107ms 0ms wasmtime 31.0.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 3.rs 83ms 3.4ms 18.2MB 73ms 0ms wasmtime 31.0.0

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 416ms 1.2ms 18.6MB 400ms 0ms wasmtime 31.0.0

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 115ms 1.4ms 18.0MB 100ms 0ms wasmtime 31.0.0

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 4206ms 2.3ms 16.7MB 4190ms 0ms wasmtime 31.0.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 355ms 3.1ms 16.8MB 340ms 0ms wasmtime 31.0.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 236ms 2.4ms 17.2MB 220ms 3ms wasmtime 31.0.0
haxe 1.hx 2396ms 7.4ms 25.6MB 2277ms 237ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 3.3MB 4340ms 873ms haxe/hl/c 4.3.6
haxe 1.hx timeout 0.0ms 3.6MB 4370ms 873ms haxe/hl/jit 1.15.0

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 32ms 0.4ms 17.4MB 20ms 0ms wasmtime 31.0.0
haxe 1.hx 255ms 2.5ms 25.6MB 230ms 30ms haxe/cpp 4.3.6
haxe 1.hx 688ms 1.2ms 3.3MB 590ms 120ms haxe/hl/c 4.3.6
haxe 1.hx 694ms 0.4ms 3.6MB 620ms 93ms haxe/hl/jit 1.15.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 2.0ms 0.2ms 2.9MB 0ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 2.3ms 0.3ms 4.4MB 0ms 0ms haxe/cpp 4.3.6
haxe 1.hx 3.8ms 0.4ms 2.9MB 0ms 0ms haxe/hl/jit 1.15.0
wasm 1.rs 6.6ms 0.4ms 17.3MB 0ms 0ms wasmtime 31.0.0

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 89ms 2.0ms 17.6MB 80ms 0ms wasmtime 31.0.0
haxe 1.hx 135ms 1.6ms 20.6MB 120ms 7ms haxe/cpp 4.3.6
haxe 1.hx 138ms 2.2ms 3.1MB 130ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 155ms 3.2ms 3.8MB 143ms 0ms haxe/hl/jit 1.15.0

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 249ms 1.0ms 16.9MB 240ms 0ms wasmtime 31.0.0
haxe 1.hx 381ms 4.0ms 25.5MB 367ms 7ms haxe/cpp 4.3.6
haxe 1.hx 401ms 4.9ms 3.0MB 393ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 460ms 6.4ms 3.8MB 447ms 0ms haxe/hl/jit 1.15.0

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 47ms 1.0ms 17.3MB 40ms 0ms wasmtime 31.0.0
haxe 1.hx 63ms 1.0ms 12.3MB 50ms 0ms haxe/cpp 4.3.6
haxe 1.hx 67ms 1.1ms 3.0MB 60ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 79ms 1.1ms 3.6MB 70ms 0ms haxe/hl/jit 1.15.0

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 8.rs 823ms 3.1ms 20.2MB 810ms 0ms wasmtime 31.0.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 8.rs 43ms 0.6ms 17.4MB 30ms 0ms wasmtime 31.0.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 885ms 5.7ms 41.3MB 857ms 10ms wasmtime 31.0.0
haxe 1.hx 902ms 4.4ms 95.1MB 1003ms 43ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 32.6MB 5047ms 467ms haxe/hl/c 4.3.6
haxe 1.hx timeout 0.0ms 55.1MB 6293ms 470ms haxe/hl/jit 1.15.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
haxe 1.hx 175ms 6.0ms 26.9MB 177ms 10ms haxe/cpp 4.3.6
wasm 1.rs 195ms 4.3ms 23.3MB 180ms 0ms wasmtime 31.0.0
haxe 1.hx 1321ms 16ms 10.8MB 1257ms 140ms haxe/hl/c 4.3.6
haxe 1.hx 1530ms 20ms 20.4MB 1577ms 137ms haxe/hl/jit 1.15.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 400ms 1.5ms 17.1MB 390ms 0ms wasmtime 31.0.0
wasm 2.rs 582ms 0.4ms 17.2MB 570ms 0ms wasmtime 31.0.0
haxe 2.hx 859ms 10ms 3.1MB 847ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 1069ms 3.8ms 3.0MB 1060ms 0ms haxe/hl/c 4.3.6
haxe 3.hx 1399ms 33ms 25.6MB 1583ms 37ms haxe/cpp 4.3.6
haxe 2.hx 2410ms 0.9ms 3.8MB 2400ms 0ms haxe/hl/jit 1.15.0
haxe 1.hx 2465ms 6.6ms 3.6MB 2453ms 0ms haxe/hl/jit 1.15.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 3.2MB 3880ms 1640ms haxe/hl/c 4.3.6
haxe 3.hx timeout 0.0ms 4.1MB 4237ms 1250ms haxe/hl/jit 1.15.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 48ms 0.4ms 17.0MB 40ms 0ms wasmtime 31.0.0
wasm 2.rs 65ms 0.1ms 17.1MB 53ms 0ms wasmtime 31.0.0
haxe 2.hx 90ms 1.9ms 3.0MB 80ms 0ms haxe/hl/c 4.3.6
haxe 1.hx 114ms 2.1ms 3.0MB 107ms 0ms haxe/hl/c 4.3.6
haxe 3.hx 157ms 3.4ms 25.8MB 153ms 10ms haxe/cpp 4.3.6
haxe 2.hx 248ms 2.3ms 3.6MB 237ms 0ms haxe/hl/jit 1.15.0
haxe 1.hx 253ms 1.2ms 3.8MB 240ms 0ms haxe/hl/jit 1.15.0
haxe 3.hx 670ms 1.6ms 3.2MB 527ms 200ms haxe/hl/c 4.3.6
haxe 2.hx 674ms 5.7ms 4.4MB 663ms 0ms haxe/cpp 4.3.6
haxe 3.hx 790ms 5.6ms 3.8MB 653ms 200ms haxe/hl/jit 1.15.0
haxe 1.hx 812ms 9.3ms 4.4MB 803ms 0ms haxe/cpp 4.3.6

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 2.rs 372ms 4.5ms 22.0MB 360ms 0ms wasmtime 31.0.0
wasm 1.rs 481ms 4.7ms 56.1MB 463ms 0ms wasmtime 31.0.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 97ms 1.6ms 27.0MB 83ms 0ms wasmtime 31.0.0
wasm 2.rs 98ms 1.4ms 18.3MB 83ms 0ms wasmtime 31.0.0

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 2.rs 2163ms 8.9ms 18.1MB 2150ms 0ms wasmtime 31.0.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 2.rs 517ms 2.5ms 17.3MB 507ms 0ms wasmtime 31.0.0

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 3487ms 19ms 17.1MB 3473ms 0ms wasmtime 31.0.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 878ms 1.3ms 17.1MB 863ms 0ms wasmtime 31.0.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 2.rs 3601ms 2.7ms 16.9MB 3587ms 0ms wasmtime 31.0.0
haxe 1.hx 3955ms 12ms 3.3MB 3947ms 0ms haxe/hl/c 4.3.6
wasm 7.rs 4897ms 8.1ms 16.8MB 4880ms 0ms wasmtime 31.0.0
haxe 1.hx timeout 0.0ms 6.9MB 4990ms 0ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 3.7MB 4990ms 0ms haxe/hl/jit 1.15.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 2.rs 908ms 1.2ms 16.9MB 897ms 0ms wasmtime 31.0.0
haxe 1.hx 1001ms 3.8ms 3.1MB 983ms 0ms haxe/hl/c 4.3.6
wasm 7.rs 1232ms 2.1ms 16.8MB 1220ms 0ms wasmtime 31.0.0
haxe 1.hx 2398ms 1.4ms 6.6MB 2387ms 0ms haxe/cpp 4.3.6
haxe 1.hx timeout 0.0ms 3.9MB 4987ms 0ms haxe/hl/jit 1.15.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 2.rs 235ms 2.0ms 16.7MB 220ms 0ms wasmtime 31.0.0
haxe 1.hx 257ms 1.4ms 3.0MB 250ms 0ms haxe/hl/c 4.3.6
wasm 7.rs 315ms 1.3ms 17.3MB 300ms 0ms wasmtime 31.0.0
haxe 1.hx 603ms 0.6ms 5.4MB 590ms 0ms haxe/cpp 4.3.6
haxe 1.hx 2229ms 148ms 3.6MB 2217ms 0ms haxe/hl/jit 1.15.0