Wasm VS Rust benchmarks

Current benchmark data was generated on Tue Dec 31 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
rust 4.rs 1176ms 7.2ms 33.8MB 1153ms 7ms rustc 1.83.0
rust 5.rs 1261ms 3.1ms 33.8MB 1233ms 10ms rustc 1.83.0
rust 3.rs 1415ms 35ms 49.8MB 1373ms 27ms rustc 1.83.0
wasm 5.rs 1607ms 21ms 37.2MB 1587ms 7ms wasmtime 28.0.0
wasm 4.rs 1657ms 9.1ms 34.9MB 1637ms 7ms wasmtime 28.0.0
wasm 3.rs 1679ms 45ms 50.9MB 1657ms 10ms wasmtime 28.0.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 4.rs 110ms 0.7ms 5.8MB 97ms 0ms rustc 1.83.0
rust 5.rs 119ms 3.8ms 5.8MB 107ms 0ms rustc 1.83.0
rust 3.rs 130ms 2.4ms 7.8MB 117ms 0ms rustc 1.83.0
wasm 5.rs 157ms 4.7ms 25.2MB 147ms 0ms wasmtime 28.0.0
wasm 3.rs 166ms 8.6ms 23.2MB 150ms 3ms wasmtime 28.0.0
wasm 4.rs 206ms 53ms 23.0MB 190ms 0ms wasmtime 28.0.0

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 3-m.rs 532ms 58ms 11.0MB 2017ms 47ms rustc 1.83.0
rust 5-m.rs 590ms 52ms 7.4MB 2213ms 77ms rustc 1.83.0
rust 1-m.rs 937ms 10ms 12.3MB 3370ms 293ms rustc 1.83.0
wasm 3.rs 1074ms 15ms 23.1MB 1060ms 3ms wasmtime 28.0.0
rust 3.rs 1091ms 13ms 9.3MB 1040ms 37ms rustc 1.83.0
rust 4.rs 1822ms 11ms 7.4MB 1810ms 0ms rustc 1.83.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 5-m.rs 50ms 2.6ms 5.3MB 133ms 20ms rustc 1.83.0
rust 3-m.rs 52ms 1.5ms 7.9MB 150ms 20ms rustc 1.83.0
rust 3.rs 73ms 3.0ms 4.0MB 60ms 0ms rustc 1.83.0
wasm 3.rs 76ms 1.9ms 19.5MB 57ms 3ms wasmtime 28.0.0
rust 1-m.rs 77ms 7.5ms 5.8MB 220ms 50ms rustc 1.83.0
rust 4.rs 110ms 2.4ms 3.4MB 100ms 0ms rustc 1.83.0

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 108ms 0.9ms 3.6MB 100ms 0ms rustc 1.83.0
rust 2.rs 389ms 4.7ms 3.6MB 380ms 0ms rustc 1.83.0
wasm 1.rs 400ms 3.8ms 22.3MB 383ms 0ms wasmtime 28.0.0

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 31ms 0.7ms 2.9MB 20ms 0ms rustc 1.83.0
rust 2.rs 71ms 1.3ms 3.0MB 60ms 0ms rustc 1.83.0
wasm 1.rs 111ms 2.8ms 21.7MB 100ms 0ms wasmtime 28.0.0

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 3-im.rs 394ms 5.6ms 6.0MB 1513ms 0ms rustc 1.83.0
rust 5-m.rs 538ms 7.1ms 4.0MB 2067ms 0ms rustc 1.83.0
rust 2-im.rs 597ms 11ms 4.0MB 2270ms 0ms rustc 1.83.0
rust 1-m.rs 928ms 3.9ms 4.0MB 3580ms 3ms rustc 1.83.0
rust 3-i.rs 1420ms 7.0ms 1.9MB 1410ms 0ms rustc 1.83.0
rust 2-i.rs 1659ms 11ms 1.8MB 1647ms 0ms rustc 1.83.0
rust 1.rs 2517ms 13ms 1.8MB 2507ms 0ms rustc 1.83.0
wasm 1.rs 4048ms 73ms 20.5MB 4037ms 0ms wasmtime 28.0.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 3-im.rs 38ms 1.2ms 4.0MB 120ms 0ms rustc 1.83.0
rust 5-m.rs 53ms 1.3ms 6.0MB 160ms 0ms rustc 1.83.0
rust 2-im.rs 60ms 1.7ms 4.0MB 193ms 0ms rustc 1.83.0
rust 1-m.rs 87ms 2.7ms 6.0MB 293ms 0ms rustc 1.83.0
rust 3-i.rs 121ms 4.1ms 1.9MB 113ms 0ms rustc 1.83.0
rust 2-i.rs 144ms 3.2ms 1.8MB 133ms 0ms rustc 1.83.0
rust 1.rs 218ms 6.6ms 1.8MB 207ms 0ms rustc 1.83.0
wasm 1.rs 336ms 2.6ms 19.2MB 320ms 0ms wasmtime 28.0.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 5c-m.rs 85ms 1.4ms 4.8MB 237ms 0ms rustc 1.83.0
rust 5-m.rs 92ms 2.4ms 4.8MB 300ms 0ms rustc 1.83.0
rust 1c.rs 156ms 3.7ms 1.9MB 147ms 0ms rustc 1.83.0
rust 1.rs 189ms 6.0ms 1.9MB 177ms 0ms rustc 1.83.0
wasm 1.rs 223ms 4.1ms 19.0MB 203ms 3ms wasmtime 28.0.0

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 5c-m.rs 15ms 0.7ms 4.8MB 23ms 0ms rustc 1.83.0
rust 5-m.rs 16ms 0.1ms 4.8MB 27ms 0ms rustc 1.83.0
rust 1c.rs 18ms 0.1ms 1.9MB 10ms 0ms rustc 1.83.0
rust 1.rs 21ms 0.3ms 1.9MB 10ms 0ms rustc 1.83.0
wasm 1.rs 29ms 0.1ms 19.3MB 20ms 0ms wasmtime 28.0.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 1.2ms 0.1ms 1.8MB 0ms 0ms rustc 1.83.0
rust 1.rs 1.2ms 0.1ms 1.8MB 0ms 0ms rustc 1.85.0-nightly
wasm 1.rs 6.5ms 0.4ms 19.4MB 0ms 0ms wasmtime 28.0.0

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 0-unsafe.rs 34ms 1.7ms 1.9MB 23ms 0ms rustc 1.83.0
rust 1.rs 46ms 4.3ms 2.0MB 33ms 0ms rustc 1.83.0
wasm 1.rs 81ms 1.3ms 19.2MB 70ms 0ms wasmtime 28.0.0

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 0-unsafe.rs 141ms 8.2ms 1.9MB 133ms 0ms rustc 1.83.0
rust 1.rs 170ms 7.7ms 2.0MB 157ms 0ms rustc 1.83.0
wasm 1.rs 224ms 8.0ms 19.1MB 207ms 0ms wasmtime 28.0.0

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 0-unsafe.rs 23ms 0.5ms 1.9MB 10ms 0ms rustc 1.83.0
rust 1.rs 28ms 1.9ms 1.9MB 17ms 0ms rustc 1.83.0
wasm 1.rs 44ms 1.6ms 19.1MB 33ms 0ms wasmtime 28.0.0

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 9.rs 248ms 0.5ms 4.8MB 240ms 0ms rustc 1.85.0-nightly
rust 8.rs 291ms 2.6ms 4.9MB 277ms 0ms rustc 1.83.0
wasm 8.rs 773ms 10ms 22.1MB 760ms 0ms wasmtime 28.0.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 9.rs 12ms 0.4ms 1.9MB 0ms 0ms rustc 1.85.0-nightly
rust 8.rs 15ms 0.5ms 1.9MB 10ms 0ms rustc 1.83.0
wasm 8.rs 40ms 0.6ms 21.2MB 30ms 0ms wasmtime 28.0.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 657ms 8.6ms 33.8MB 637ms 3ms rustc 1.83.0
wasm 1.rs 815ms 3.5ms 42.9MB 787ms 10ms wasmtime 28.0.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 145ms 2.9ms 9.8MB 133ms 0ms rustc 1.83.0
wasm 1.rs 179ms 1.6ms 27.0MB 160ms 7ms wasmtime 28.0.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 4-i.rs 160ms 3.5ms 1.8MB 150ms 0ms rustc 1.83.0
rust 7-i.rs 228ms 2.2ms 1.8MB 220ms 0ms rustc 1.83.0
rust 1.rs 228ms 5.2ms 1.8MB 213ms 0ms rustc 1.83.0
rust 2.rs 263ms 1.3ms 1.8MB 253ms 0ms rustc 1.83.0
rust 3.rs 269ms 1.6ms 1.9MB 257ms 0ms rustc 1.85.0-nightly
wasm 1.rs 376ms 1.9ms 18.8MB 363ms 0ms wasmtime 28.0.0
wasm 2.rs 550ms 2.4ms 18.8MB 537ms 3ms wasmtime 28.0.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 4-i.rs 18ms 0.7ms 1.8MB 10ms 0ms rustc 1.83.0
rust 1.rs 25ms 0.4ms 1.8MB 17ms 0ms rustc 1.83.0
rust 7-i.rs 25ms 0.7ms 1.8MB 20ms 0ms rustc 1.83.0
rust 2.rs 28ms 0.0ms 1.8MB 20ms 0ms rustc 1.83.0
rust 3.rs 28ms 0.1ms 1.8MB 20ms 0ms rustc 1.85.0-nightly
wasm 1.rs 46ms 1.3ms 18.9MB 30ms 0ms wasmtime 28.0.0
wasm 2.rs 62ms 1.3ms 20.8MB 50ms 0ms wasmtime 28.0.0

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 277ms 3.8ms 40.9MB 267ms 0ms rustc 1.83.0
rust 2.rs 307ms 3.2ms 6.7MB 290ms 0ms rustc 1.83.0
wasm 2.rs 308ms 3.3ms 23.9MB 300ms 0ms wasmtime 28.0.0
wasm 1.rs 437ms 1.5ms 58.0MB 417ms 3ms wasmtime 28.0.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 59ms 0.6ms 11.6MB 47ms 0ms rustc 1.83.0
rust 2.rs 75ms 0.2ms 2.9MB 70ms 0ms rustc 1.83.0
wasm 2.rs 80ms 0.2ms 23.9MB 70ms 0ms wasmtime 28.0.0
wasm 1.rs 90ms 2.3ms 28.7MB 77ms 3ms wasmtime 28.0.0

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 1461ms 11ms 2.7MB 1253ms 183ms rustc 1.83.0
rust 2.rs 1636ms 13ms 2.8MB 1527ms 93ms rustc 1.83.0
wasm 2.rs 2042ms 3.2ms 19.8MB 2027ms 0ms wasmtime 28.0.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 306ms 1.7ms 2.4MB 283ms 3ms rustc 1.83.0
rust 2.rs 367ms 5.1ms 2.5MB 353ms 0ms rustc 1.83.0
wasm 2.rs 486ms 6.6ms 19.2MB 470ms 3ms wasmtime 28.0.0

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 0.rs 113ms 1.2ms 1.9MB 100ms 0ms rustc 1.83.0
rust 1.rs 1337ms 7.5ms 1.9MB 1330ms 0ms rustc 1.83.0
wasm 1.rs 3257ms 26ms 19.2MB 3240ms 0ms wasmtime 28.0.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 0.rs 31ms 0.6ms 1.8MB 20ms 0ms rustc 1.83.0
rust 1.rs 345ms 5.2ms 1.9MB 333ms 0ms rustc 1.83.0
wasm 1.rs 827ms 11ms 18.7MB 810ms 0ms wasmtime 28.0.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 8-m.rs 469ms 0.9ms 4.6MB 1810ms 0ms rustc 1.85.0-nightly
rust 7-m.rs 471ms 4.6ms 4.2MB 1817ms 3ms rustc 1.83.0
rust 8.rs 961ms 14ms 2.4MB 950ms 0ms rustc 1.85.0-nightly
rust 2-m.rs 1855ms 2.8ms 4.1MB 7283ms 7ms rustc 1.83.0
rust 7.rs 1994ms 3.4ms 1.9MB 1987ms 0ms rustc 1.83.0
wasm 2.rs 3400ms 18ms 18.6MB 3387ms 0ms wasmtime 28.0.0
rust 2.rs 3948ms 11ms 2.0MB 3937ms 0ms rustc 1.83.0
wasm 7.rs 4694ms 77ms 18.6MB 4683ms 0ms wasmtime 28.0.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 7-m.rs 121ms 0.3ms 4.1MB 443ms 3ms rustc 1.83.0
rust 8-m.rs 123ms 3.8ms 4.4MB 443ms 0ms rustc 1.85.0-nightly
rust 8.rs 240ms 1.0ms 2.1MB 227ms 0ms rustc 1.85.0-nightly
rust 2-m.rs 468ms 6.0ms 4.1MB 1797ms 3ms rustc 1.83.0
rust 7.rs 498ms 3.3ms 1.8MB 490ms 0ms rustc 1.83.0
wasm 2.rs 856ms 6.8ms 18.7MB 843ms 0ms wasmtime 28.0.0
rust 2.rs 1001ms 10ms 1.9MB 987ms 0ms rustc 1.83.0
wasm 7.rs 1168ms 17ms 20.5MB 1160ms 0ms wasmtime 28.0.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 7-m.rs 34ms 0.6ms 4.1MB 103ms 0ms rustc 1.83.0
rust 8-m.rs 35ms 0.2ms 4.2MB 110ms 0ms rustc 1.85.0-nightly
rust 8.rs 63ms 1.0ms 2.1MB 50ms 0ms rustc 1.85.0-nightly
rust 2-m.rs 123ms 2.3ms 6.1MB 447ms 3ms rustc 1.83.0
rust 7.rs 135ms 1.1ms 1.8MB 123ms 0ms rustc 1.83.0
wasm 2.rs 221ms 1.7ms 20.5MB 210ms 0ms wasmtime 28.0.0
rust 2.rs 256ms 5.0ms 1.9MB 247ms 0ms rustc 1.83.0
wasm 7.rs 298ms 4.7ms 18.9MB 290ms 0ms wasmtime 28.0.0