Chapel VS Wasm benchmarks

Current benchmark data was generated on Thu May 01 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
wasm 5.rs 1774ms 4.7ms 33.7MB 1757ms 7ms wasmtime 32.0.0
wasm 3.rs 1818ms 20ms 49.7MB 1790ms 13ms wasmtime 32.0.0
wasm 4.rs 1821ms 4.3ms 33.8MB 1803ms 7ms wasmtime 32.0.0
chapel 4.chpl 1953ms 5.8ms 62.4MB 1947ms 0ms chpl 1.31.0
chapel 3.chpl 2034ms 5.7ms 62.3MB 2027ms 0ms chpl 1.31.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 5.rs 170ms 2.0ms 19.7MB 160ms 0ms wasmtime 32.0.0
wasm 4.rs 177ms 2.1ms 19.7MB 163ms 0ms wasmtime 32.0.0
wasm 3.rs 180ms 5.3ms 21.7MB 163ms 0ms wasmtime 32.0.0
chapel 4.chpl 184ms 0.5ms 32.3MB 180ms 0ms chpl 1.31.0
chapel 3.chpl 189ms 2.4ms 32.3MB 183ms 0ms chpl 1.31.0

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 3.rs 1138ms 15ms 20.2MB 1123ms 0ms wasmtime 32.0.0
chapel 1-m.chpl 2236ms 75ms 571.9MB 4350ms 80ms chpl 1.31.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 3.rs 82ms 1.1ms 20.2MB 70ms 0ms wasmtime 32.0.0
chapel 1-m.chpl 193ms 3.2ms 540.5MB 307ms 50ms chpl 1.31.0

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 74ms 1.0ms 32.5MB 70ms 0ms chpl 1.31.0
wasm 1.rs 421ms 3.5ms 19.4MB 407ms 0ms wasmtime 32.0.0

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 34ms 0.7ms 30.5MB 30ms 0ms chpl 1.31.0
wasm 1.rs 115ms 2.5ms 18.8MB 100ms 0ms wasmtime 32.0.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 5-m.chpl 107ms 2.2ms 28.4MB 190ms 0ms chpl 1.31.0
wasm 1.rs 236ms 2.0ms 17.9MB 223ms 0ms wasmtime 32.0.0

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 5.chpl 21ms 1.7ms 28.4MB 20ms 0ms chpl 1.31.0
wasm 1.rs 31ms 1.2ms 17.8MB 20ms 0ms wasmtime 32.0.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 6.4ms 0.3ms 16.1MB 0ms 0ms wasmtime 32.0.0
chapel 1.chpl 11ms 0.5ms 28.8MB 0ms 0ms chpl 1.31.0

knucleotide

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3-m.chpl 751ms 2.2ms 85.0MB 1420ms 10ms chpl 1.31.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3-m.chpl 116ms 1.0ms 87.0MB 200ms 7ms chpl 1.31.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 324ms 3.1ms 28.8MB 320ms 0ms chpl 1.31.0
wasm 1.rs 404ms 2.4ms 17.8MB 393ms 0ms wasmtime 32.0.0
wasm 2.rs 563ms 3.0ms 17.9MB 550ms 0ms wasmtime 32.0.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 45ms 1.4ms 28.8MB 40ms 0ms chpl 1.31.0
wasm 1.rs 48ms 1.3ms 19.8MB 40ms 0ms wasmtime 32.0.0
wasm 2.rs 63ms 0.2ms 17.9MB 50ms 0ms wasmtime 32.0.0

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 448ms 1.7ms 30.4MB 440ms 0ms chpl 1.31.0
wasm 2.rs 2190ms 4.4ms 19.1MB 2173ms 0ms wasmtime 32.0.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 114ms 1.1ms 30.3MB 110ms 0ms chpl 1.31.0
wasm 2.rs 519ms 3.4ms 18.1MB 507ms 0ms wasmtime 32.0.0

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3.chpl 1396ms 9.5ms 220.2MB 1350ms 40ms chpl 1.31.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3.chpl 162ms 3.8ms 48.9MB 140ms 17ms chpl 1.31.0

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 1187ms 11ms 29.1MB 1183ms 0ms chpl 1.31.0
wasm 1.rs 3581ms 22ms 17.6MB 3567ms 0ms wasmtime 32.0.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 307ms 3.0ms 29.0MB 303ms 0ms chpl 1.31.0
wasm 1.rs 907ms 5.9ms 17.6MB 897ms 0ms wasmtime 32.0.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1-m.chpl 1928ms 23ms 28.9MB 3827ms 0ms chpl 1.31.0
wasm 2.rs 3694ms 3.7ms 17.6MB 3683ms 0ms wasmtime 32.0.0
chapel 1.chpl 3719ms 13ms 28.8MB 3713ms 0ms chpl 1.31.0
wasm 7.rs 4898ms 2.5ms 18.1MB 4883ms 0ms wasmtime 32.0.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1-m.chpl 492ms 2.8ms 28.8MB 960ms 0ms chpl 1.31.0
wasm 2.rs 934ms 2.7ms 17.7MB 920ms 0ms wasmtime 32.0.0
chapel 1.chpl 944ms 3.9ms 28.8MB 937ms 0ms chpl 1.31.0
wasm 7.rs 1229ms 0.8ms 19.5MB 1217ms 0ms wasmtime 32.0.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1-m.chpl 134ms 1.5ms 28.9MB 247ms 0ms chpl 1.31.0
wasm 2.rs 239ms 1.7ms 17.4MB 223ms 0ms wasmtime 32.0.0
chapel 1.chpl 247ms 2.2ms 28.8MB 240ms 0ms chpl 1.31.0
wasm 7.rs 315ms 1.9ms 18.2MB 300ms 0ms wasmtime 32.0.0