Wasm VS Crystal benchmarks

Current benchmark data was generated on Fri Aug 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
crystal 1.cr 1231ms 8.3ms 64.2MB 1203ms 10ms crystal 1.17.0
wasm 5.rs 1754ms 5.6ms 33.8MB 1733ms 10ms wasmtime 35.0.0
wasm 3.rs 1818ms 28ms 49.8MB 1783ms 20ms wasmtime 35.0.0
wasm 4.rs 1833ms 6.3ms 33.7MB 1813ms 7ms wasmtime 35.0.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 104ms 1.6ms 11.0MB 90ms 0ms crystal 1.17.0
wasm 5.rs 171ms 2.9ms 19.8MB 160ms 0ms wasmtime 35.0.0
wasm 4.rs 174ms 0.5ms 19.8MB 160ms 0ms wasmtime 35.0.0
wasm 3.rs 181ms 14ms 21.8MB 167ms 0ms wasmtime 35.0.0

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 3.rs 1118ms 22ms 20.1MB 1100ms 0ms wasmtime 35.0.0
crystal 1.cr 1489ms 15ms 19.9MB 1420ms 57ms crystal 1.17.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 3.rs 81ms 2.8ms 20.2MB 70ms 0ms wasmtime 35.0.0
crystal 1.cr 82ms 4.6ms 7.1MB 57ms 10ms crystal 1.17.0

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 57ms 1.8ms 6.5MB 40ms 3ms crystal 1.17.0
wasm 1.rs 416ms 5.6ms 19.5MB 403ms 0ms wasmtime 35.0.0

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 22ms 1.7ms 5.3MB 10ms 0ms crystal 1.17.0
wasm 1.rs 112ms 2.4ms 18.7MB 100ms 0ms wasmtime 35.0.0

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 2510ms 4.1ms 2.9MB 2497ms 0ms crystal 1.17.0
wasm 1.rs 4146ms 2.1ms 17.3MB 4133ms 0ms wasmtime 35.0.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 207ms 2.7ms 2.9MB 200ms 0ms crystal 1.17.0
wasm 1.rs 348ms 0.1ms 17.4MB 340ms 0ms wasmtime 35.0.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 220ms 0.6ms 18.0MB 210ms 0ms wasmtime 35.0.0
crystal 2.cr 540ms 2.0ms 3.6MB 450ms 77ms crystal 1.17.0
crystal 1.cr 681ms 2.0ms 14.6MB 570ms 97ms crystal 1.17.0

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 30ms 0.9ms 18.1MB 20ms 0ms wasmtime 35.0.0
crystal 2.cr 57ms 0.8ms 3.6MB 40ms 0ms crystal 1.17.0
crystal 1.cr 72ms 0.8ms 4.4MB 53ms 7ms crystal 1.17.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 1.9ms 0.1ms 2.9MB 0ms 0ms crystal 1.17.0
wasm 1.rs 6.4ms 0.3ms 18.0MB 0ms 0ms wasmtime 35.0.0

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 37ms 0.9ms 3.0MB 30ms 0ms crystal 1.17.0
crystal 1.cr 70ms 1.9ms 3.0MB 60ms 0ms crystal 1.17.0
wasm 1.rs 93ms 1.9ms 17.6MB 80ms 0ms wasmtime 35.0.0

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 105ms 1.9ms 3.0MB 97ms 0ms crystal 1.17.0
crystal 1.cr 201ms 2.2ms 3.0MB 190ms 0ms crystal 1.17.0
wasm 1.rs 255ms 0.8ms 18.2MB 240ms 0ms wasmtime 35.0.0

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 19ms 1.2ms 3.0MB 10ms 0ms crystal 1.17.0
crystal 1.cr 33ms 1.2ms 3.0MB 20ms 0ms crystal 1.17.0
wasm 1.rs 47ms 0.2ms 18.2MB 40ms 0ms wasmtime 35.0.0

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 314ms 1.7ms 9.3MB 303ms 0ms crystal 1.17.0
wasm 8.rs 817ms 1.4ms 21.1MB 803ms 0ms wasmtime 35.0.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 17ms 0.1ms 5.8MB 10ms 0ms crystal 1.17.0
wasm 8.rs 42ms 1.1ms 18.1MB 30ms 0ms wasmtime 35.0.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 838ms 12ms 64.2MB 820ms 7ms crystal 1.17.0
wasm 1.rs 880ms 4.4ms 41.7MB 857ms 10ms wasmtime 35.0.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 177ms 4.2ms 22.3MB 160ms 0ms crystal 1.17.0
wasm 1.rs 192ms 0.3ms 24.1MB 180ms 0ms wasmtime 35.0.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 345ms 2.9ms 3.4MB 337ms 0ms crystal 1.17.0
crystal 1.cr 346ms 3.1ms 3.4MB 337ms 0ms crystal 1.17.0
wasm 1.rs 410ms 1.4ms 17.8MB 400ms 0ms wasmtime 35.0.0
wasm 2.rs 565ms 5.2ms 17.9MB 553ms 0ms wasmtime 35.0.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 37ms 0.5ms 3.4MB 30ms 0ms crystal 1.17.0
crystal 1.cr 39ms 0.1ms 3.4MB 30ms 0ms crystal 1.17.0
wasm 1.rs 48ms 0.9ms 17.8MB 40ms 0ms wasmtime 35.0.0
wasm 2.rs 65ms 1.2ms 17.8MB 50ms 0ms wasmtime 35.0.0

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 301ms 3.1ms 8.3MB 290ms 0ms crystal 1.17.0
wasm 2.rs 385ms 7.3ms 22.7MB 370ms 0ms wasmtime 35.0.0
crystal 1.cr 420ms 4.6ms 43.0MB 403ms 0ms crystal 1.17.0
wasm 1.rs 450ms 3.8ms 56.9MB 437ms 0ms wasmtime 35.0.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 74ms 0.2ms 4.5MB 70ms 0ms crystal 1.17.0
crystal 1.cr 89ms 0.6ms 13.2MB 80ms 0ms crystal 1.17.0
wasm 1.rs 92ms 1.1ms 27.5MB 80ms 0ms wasmtime 35.0.0
wasm 2.rs 99ms 0.8ms 19.1MB 90ms 0ms wasmtime 35.0.0

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 1960ms 30ms 6.3MB 1927ms 17ms crystal 1.17.0
wasm 2.rs 2146ms 21ms 18.8MB 2133ms 0ms wasmtime 35.0.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 438ms 11ms 5.0MB 430ms 0ms crystal 1.17.0
wasm 2.rs 506ms 2.3ms 18.1MB 490ms 0ms wasmtime 35.0.0

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 3412ms 3.1ms 17.5MB 3400ms 0ms wasmtime 35.0.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 869ms 7.9ms 17.5MB 857ms 0ms wasmtime 35.0.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 7.rs 3602ms 3.8ms 18.1MB 3590ms 0ms wasmtime 35.0.0
wasm 2.rs 3607ms 9.5ms 17.8MB 3590ms 0ms wasmtime 35.0.0
crystal 1.cr 3758ms 11ms 4.5MB 3750ms 0ms crystal 1.17.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 2.rs 905ms 0.6ms 17.4MB 890ms 0ms wasmtime 35.0.0
wasm 7.rs 909ms 1.9ms 17.6MB 897ms 0ms wasmtime 35.0.0
crystal 1.cr 941ms 1.2ms 4.5MB 930ms 0ms crystal 1.17.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 7.rs 233ms 1.0ms 17.8MB 220ms 0ms wasmtime 35.0.0
wasm 2.rs 234ms 1.7ms 17.3MB 220ms 0ms wasmtime 35.0.0
crystal 1.cr 242ms 3.7ms 3.9MB 233ms 0ms crystal 1.17.0