Go VS Wasm benchmarks

Current benchmark data was generated on Thu Sep 22 2022, full log can be found HERE

CONTRIBUTIONS are WELCOME!

[x86_64][2 cores] Intel(R) Xeon(R) Platinum 8370C CPU @ 2.80GHz (Model 106)

* -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 3.rs 1991ms 14ms 51.1MB 1967ms 7ms wasmedgec 0.11.0
wasm 3.rs 2042ms 6.2ms 37.8MB 2010ms 17ms wasmer/llvm 2.3.0
wasm 5.rs 2143ms 150ms 35.0MB 2123ms 0ms wasmedgec 0.11.0
wasm 4.rs 2223ms 3.6ms 34.4MB 2203ms 7ms wasmedgec 0.11.0
wasm 4.rs 2416ms 8.0ms 21.7MB 2390ms 7ms wasmer/llvm 2.3.0
wasm 3.rs 2477ms 19ms 42.5MB 2457ms 0ms wasmtime 1.0.0
wasm 5.rs 2565ms 1.4ms 21.9MB 2547ms 10ms wasmer/llvm 2.3.0
wasm 5.rs 2651ms 56ms 59.5MB 2637ms 17ms node 16.17.0
wasm 4.rs 2771ms 42ms 58.6MB 2777ms 13ms node 16.17.0
wasm 3.rs 2796ms 31ms 78.0MB 2793ms 20ms node 16.17.0
wasm 5.rs 2916ms 20ms 26.6MB 2893ms 7ms wasmtime 1.0.0
go 1.go 3006ms 7.3ms 46.0MB 4327ms 47ms go 1.19.1
wasm 4.rs 3153ms 28ms 26.5MB 3130ms 7ms wasmtime 1.0.0
go 1.go 4239ms 23ms 37.9MB 4220ms 0ms tinygo 0.25.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 3.rs 192ms 0.5ms 9.8MB 173ms 0ms wasmer/llvm 2.3.0
wasm 3.rs 194ms 7.6ms 23.0MB 180ms 0ms wasmedgec 0.11.0
wasm 5.rs 211ms 19ms 21.0MB 197ms 0ms wasmedgec 0.11.0
wasm 4.rs 222ms 11ms 20.8MB 210ms 0ms wasmedgec 0.11.0
wasm 4.rs 227ms 0.3ms 8.0MB 217ms 0ms wasmer/llvm 2.3.0
wasm 3.rs 234ms 1.5ms 14.5MB 220ms 0ms wasmtime 1.0.0
wasm 5.rs 244ms 0.1ms 7.9MB 230ms 0ms wasmer/llvm 2.3.0
go 1.go 259ms 1.5ms 8.1MB 337ms 3ms go 1.19.1
wasm 5.rs 280ms 8.4ms 12.6MB 263ms 0ms wasmtime 1.0.0
wasm 4.rs 301ms 4.3ms 12.6MB 283ms 3ms wasmtime 1.0.0
wasm 3.rs 332ms 5.2ms 46.4MB 340ms 3ms node 16.17.0
wasm 4.rs 339ms 8.9ms 44.0MB 353ms 7ms node 16.17.0
go 1.go 349ms 0.6ms 6.0MB 340ms 0ms tinygo 0.25.0
wasm 5.rs 369ms 16ms 45.6MB 347ms 10ms node 16.17.0

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 787ms 149ms 13.6MB 1523ms 3ms go 1.19.1
wasm 3.rs 1268ms 0.5ms 8.0MB 1257ms 0ms wasmer/llvm 2.3.0
wasm 3.rs 1530ms 20ms 48.2MB 1570ms 20ms node 16.17.0
wasm 3.rs 1588ms 41ms 12.6MB 1573ms 0ms wasmtime 1.0.0
go 1.go 1694ms 7.1ms 257.2MB 1627ms 53ms tinygo 0.25.0
wasm 3.rs 1938ms 4.0ms 22.6MB 1920ms 3ms wasmedgec 0.11.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 57ms 8.6ms 5.4MB 87ms 0ms go 1.19.1
wasm 3.rs 84ms 0.8ms 7.0MB 70ms 0ms wasmer/llvm 2.3.0
wasm 3.rs 105ms 3.6ms 11.2MB 93ms 0ms wasmtime 1.0.0
wasm 3.rs 134ms 0.6ms 19.8MB 123ms 0ms wasmedgec 0.11.0
wasm 3.rs 216ms 4.3ms 48.2MB 267ms 7ms node 16.17.0
go 1.go 272ms 0.3ms 68.7MB 247ms 10ms tinygo 0.25.0

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 168ms 2.7ms 8.5MB 157ms 0ms go 1.19.1
wasm 1.rs 465ms 0.4ms 7.4MB 453ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 479ms 1.1ms 20.2MB 463ms 3ms wasmedgec 0.11.0
wasm 1.rs 636ms 30ms 12.1MB 627ms 0ms wasmtime 1.0.0
wasm 1.rs 708ms 1.5ms 49.7MB 747ms 13ms node 16.17.0

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 49ms 1.8ms 8.2MB 37ms 0ms go 1.19.1
wasm 1.rs 121ms 0.4ms 6.5MB 110ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 131ms 0.8ms 21.6MB 120ms 0ms wasmedgec 0.11.0
wasm 1.rs 167ms 8.2ms 11.6MB 160ms 0ms wasmtime 1.0.0
wasm 1.rs 272ms 3.4ms 48.8MB 317ms 7ms node 16.17.0

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 1443ms 1.4ms 3.0MB 2800ms 0ms go 1.19.1
go 3.go 2937ms 1.2ms 49.1MB 2913ms 7ms tinygo 0.25.0
wasm 1.rs 4694ms 29ms 44.0MB 4713ms 0ms node 16.17.0
wasm 1.rs 4954ms 1.8ms 4.9MB 4940ms 0ms wasmer/llvm 2.3.0
wasm 1.rs timeout 0.0ms 0.0MB 0ms 0ms wasmedgec 0.11.0
wasm 1.rs timeout 0.0ms 0.0MB 0ms 0ms wasmtime 1.0.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 147ms 2.4ms 3.0MB 223ms 0ms go 1.19.1
go 3.go 314ms 1.1ms 49.9MB 283ms 7ms tinygo 0.25.0
wasm 1.rs 416ms 3.6ms 4.8MB 403ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 426ms 3.1ms 9.4MB 413ms 0ms wasmtime 1.0.0
wasm 1.rs 447ms 0.8ms 18.6MB 433ms 0ms wasmedgec 0.11.0
wasm 1.rs 516ms 84ms 45.8MB 527ms 7ms node 16.17.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 242ms 1.6ms 2.9MB 440ms 0ms go 1.19.1
wasm 1.rs 347ms 0.2ms 6.1MB 333ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 350ms 2.0ms 9.5MB 337ms 0ms wasmtime 1.0.0
wasm 1.rs 359ms 0.2ms 18.9MB 340ms 0ms wasmedgec 0.11.0
wasm 1.rs 465ms 1.2ms 43.7MB 480ms 3ms node 16.17.0

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 30ms 0.1ms 2.9MB 40ms 0ms go 1.19.1
wasm 1.rs 38ms 0.2ms 6.1MB 30ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 42ms 0.6ms 9.2MB 30ms 0ms wasmtime 1.0.0
wasm 1.rs 44ms 0.5ms 18.5MB 37ms 0ms wasmedgec 0.11.0
wasm 1.rs 126ms 2.2ms 47.5MB 143ms 3ms node 16.17.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 1.6ms 0.9ms 0.0MB 0ms 0ms tinygo 0.25.0
go 1.go 2.6ms 0.5ms 2.9MB 0ms 0ms go 1.19.1
wasm 1.rs 2.7ms 0.5ms 4.9MB 0ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 6.0ms 0.9ms 9.2MB 0ms 0ms wasmtime 1.0.0
wasm 1.rs 8.5ms 2.6ms 18.4MB 0ms 0ms wasmedgec 0.11.0
wasm 1.rs 83ms 1.1ms 43.5MB 94ms 6ms node 16.17.0

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-http2.go 172ms 6.5ms 55.9MB 260ms 40ms go 1.19.1
go 2-m.go 551ms 17ms 170.1MB 487ms 367ms go 1.19.1
go 1-m.go 613ms 42ms 165.7MB 613ms 370ms go 1.19.1

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-http2.go 31ms 20ms 22.7MB 45ms 5ms go 1.19.1
go 1.go 131ms 9.7ms 38.4MB 73ms 67ms go 1.19.1
go 2.go 135ms 3.5ms 39.1MB 83ms 60ms go 1.19.1

json-serde

Input: sample 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 2-ffi.go 71ms 3.9ms 45.0MB 57ms 3ms go 1.19.1
go 1.go 171ms 1.4ms 18.7MB 157ms 3ms go 1.19.1

Input: canada 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 2-ffi.go 407ms 3.6ms 165.2MB 370ms 113ms go 1.19.1
go 1.go 1043ms 0.4ms 109.0MB 1030ms 47ms go 1.19.1

knucleotide

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 7-m.go 1505ms 5.6ms 42.6MB 2817ms 23ms go 1.19.1

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 7-m.go 224ms 3.0ms 22.4MB 363ms 17ms go 1.19.1

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 126ms 1.6ms 6.3MB 113ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 137ms 0.8ms 18.6MB 127ms 0ms wasmedgec 0.11.0
wasm 1.rs 149ms 1.7ms 10.9MB 140ms 0ms wasmtime 1.0.0
go 3.go 166ms 1.1ms 0.3MB 160ms 0ms tinygo 0.25.0
go 3.go 175ms 0.9ms 2.9MB 160ms 0ms go 1.19.1
wasm 1.rs 227ms 4.3ms 44.6MB 243ms 7ms node 16.17.0

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 368ms 1.6ms 6.3MB 360ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 401ms 6.7ms 19.2MB 387ms 0ms wasmedgec 0.11.0
wasm 1.rs 434ms 5.4ms 10.9MB 423ms 0ms wasmtime 1.0.0
go 3.go 491ms 0.4ms 0.3MB 480ms 0ms tinygo 0.25.0
wasm 1.rs 505ms 4.3ms 44.6MB 520ms 10ms node 16.17.0
go 3.go 513ms 2.7ms 3.4MB 500ms 0ms go 1.19.1

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 62ms 1.3ms 4.9MB 50ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 71ms 0.5ms 18.6MB 60ms 0ms wasmedgec 0.11.0
wasm 1.rs 76ms 0.7ms 11.3MB 63ms 3ms wasmtime 1.0.0
go 3.go 81ms 1.2ms 0.0MB 70ms 0ms tinygo 0.25.0
go 3.go 94ms 1.0ms 3.9MB 83ms 0ms go 1.19.1
wasm 1.rs 158ms 1.7ms 44.6MB 173ms 7ms node 16.17.0

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 8.rs 1065ms 1.1ms 47.9MB 1080ms 3ms node 16.17.0
wasm 8.rs 1098ms 0.8ms 21.8MB 1083ms 0ms wasmedgec 0.11.0
wasm 8.rs 1171ms 1.3ms 9.1MB 1160ms 0ms wasmer/llvm 2.3.0
wasm 8.rs 1296ms 0.4ms 13.8MB 1280ms 0ms wasmtime 1.0.0
go 1.go 4105ms 9.6ms 7.3MB 4087ms 3ms go 1.19.1
go 1.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 8.rs 53ms 0.8ms 6.0MB 40ms 0ms wasmer/llvm 2.3.0
wasm 8.rs 55ms 0.2ms 18.9MB 40ms 0ms wasmedgec 0.11.0
wasm 8.rs 62ms 1.0ms 11.0MB 50ms 0ms wasmtime 1.0.0
wasm 8.rs 127ms 3.0ms 44.2MB 147ms 3ms node 16.17.0
go 1.go 172ms 1.6ms 2.8MB 160ms 0ms go 1.19.1
go 1.go 248ms 4.4ms 0.0MB 240ms 0ms tinygo 0.25.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 1079ms 4.2ms 42.4MB 1055ms 10ms wasmedgec 0.11.0
wasm 1.rs 1246ms 3.1ms 29.8MB 1213ms 17ms wasmer/llvm 2.3.0
wasm 1.rs 1372ms 11ms 67.5MB 1373ms 17ms node 16.17.0
wasm 1.rs 1434ms 9.1ms 34.5MB 1407ms 7ms wasmtime 1.0.0
go 1.go 1976ms 5.3ms 48.1MB 2803ms 43ms go 1.19.1
go 2.go 2305ms 5.9ms 41.3MB 3270ms 43ms go 1.19.1
go 1.go 3286ms 4.0ms 212.1MB 3233ms 33ms tinygo 0.25.0
go 2.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 1.rs 235ms 1.5ms 24.4MB 217ms 3ms wasmedgec 0.11.0
wasm 1.rs 267ms 1.0ms 11.7MB 257ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 308ms 0.9ms 16.7MB 297ms 0ms wasmtime 1.0.0
wasm 1.rs 355ms 5.1ms 49.2MB 363ms 7ms node 16.17.0
go 1.go 413ms 2.9ms 12.3MB 567ms 13ms go 1.19.1
go 2.go 485ms 2.0ms 13.0MB 663ms 17ms go 1.19.1
go 1.go 792ms 1.5ms 52.1MB 773ms 3ms tinygo 0.25.0
go 2.go 1083ms 3.6ms 39.4MB 1057ms 10ms tinygo 0.25.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 455ms 2.1ms 2.9MB 443ms 0ms go 1.19.1
wasm 1.rs 469ms 1.1ms 4.9MB 457ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 497ms 0.9ms 9.6MB 487ms 0ms wasmtime 1.0.0
wasm 1.rs 501ms 1.0ms 18.5MB 483ms 0ms wasmedgec 0.11.0
wasm 1.rs 571ms 3.9ms 48.3MB 593ms 7ms node 16.17.0
wasm 2.rs 678ms 0.6ms 18.9MB 667ms 0ms wasmedgec 0.11.0
wasm 2.rs 679ms 1.0ms 9.7MB 663ms 0ms wasmtime 1.0.0
wasm 2.rs 688ms 0.2ms 4.9MB 677ms 0ms wasmer/llvm 2.3.0
wasm 2.rs 758ms 12ms 48.3MB 783ms 10ms node 16.17.0
go 1.go 843ms 0.9ms 0.0MB 830ms 0ms tinygo 0.25.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 50ms 1.4ms 2.9MB 40ms 0ms go 1.19.1
wasm 1.rs 51ms 0.6ms 4.8MB 40ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 57ms 0.8ms 11.5MB 47ms 0ms wasmtime 1.0.0
wasm 1.rs 59ms 0.3ms 18.9MB 47ms 0ms wasmedgec 0.11.0
wasm 2.rs 72ms 0.5ms 4.8MB 60ms 0ms wasmer/llvm 2.3.0
wasm 2.rs 75ms 0.2ms 11.4MB 60ms 0ms wasmtime 1.0.0
wasm 2.rs 78ms 3.4ms 18.7MB 63ms 0ms wasmedgec 0.11.0
go 1.go 88ms 2.5ms 0.0MB 80ms 0ms tinygo 0.25.0
wasm 1.rs 150ms 5.2ms 48.3MB 177ms 7ms node 16.17.0
wasm 2.rs 171ms 3.2ms 47.7MB 193ms 7ms node 16.17.0

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 2.rs 510ms 2.9ms 10.8MB 493ms 0ms wasmer/llvm 2.3.0
wasm 2.rs 560ms 2.5ms 23.3MB 543ms 3ms wasmedgec 0.11.0
go 2.go 621ms 1.4ms 17.1MB 603ms 0ms tinygo 0.25.0
wasm 2.rs 698ms 2.2ms 15.5MB 683ms 0ms wasmtime 1.0.0
wasm 2.rs 721ms 8.6ms 48.3MB 733ms 7ms node 16.17.0
go 1.go 759ms 9.3ms 73.5MB 737ms 10ms go 1.19.1
go 1.go 797ms 15ms 42.5MB 777ms 7ms tinygo 0.25.0
wasm 1.rs 858ms 1.8ms 44.9MB 823ms 23ms wasmer/llvm 2.3.0
wasm 1.rs 871ms 40ms 57.0MB 850ms 10ms wasmedgec 0.11.0
go 2.go 905ms 4.0ms 19.8MB 890ms 7ms go 1.19.1
wasm 1.rs 1014ms 62ms 83.3MB 1027ms 10ms node 16.17.0
wasm 1.rs 1338ms 34ms 49.7MB 1320ms 3ms wasmtime 1.0.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
wasm 2.rs 119ms 0.7ms 7.3MB 107ms 0ms wasmer/llvm 2.3.0
go 1.go 129ms 1.0ms 13.6MB 120ms 0ms tinygo 0.25.0
go 1.go 131ms 3.7ms 23.9MB 117ms 3ms go 1.19.1
wasm 2.rs 139ms 1.1ms 20.1MB 123ms 0ms wasmedgec 0.11.0
wasm 1.rs 147ms 2.1ms 15.7MB 127ms 3ms wasmer/llvm 2.3.0
go 2.go 148ms 1.7ms 5.4MB 140ms 0ms tinygo 0.25.0
wasm 1.rs 151ms 0.2ms 29.6MB 140ms 0ms wasmedgec 0.11.0
wasm 2.rs 168ms 0.0ms 12.0MB 157ms 0ms wasmtime 1.0.0
go 2.go 216ms 2.6ms 7.6MB 203ms 0ms go 1.19.1
wasm 1.rs 223ms 2.2ms 20.3MB 210ms 0ms wasmtime 1.0.0
wasm 1.rs 233ms 3.5ms 59.3MB 240ms 7ms node 16.17.0
wasm 2.rs 235ms 0.8ms 44.3MB 250ms 0ms node 16.17.0

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 8.go 1424ms 4.4ms 8.5MB 1400ms 7ms go 1.19.1
wasm 2.rs 3010ms 8.2ms 7.0MB 2990ms 0ms wasmer/llvm 2.3.0
wasm 2.rs 3124ms 6.9ms 18.9MB 3107ms 0ms wasmedgec 0.11.0
wasm 2.rs 3380ms 1.0ms 11.3MB 3370ms 0ms wasmtime 1.0.0
wasm 2.rs 3675ms 39ms 48.1MB 3717ms 10ms node 16.17.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 8.go 341ms 0.8ms 8.4MB 323ms 3ms go 1.19.1
wasm 2.rs 709ms 3.6ms 6.3MB 697ms 0ms wasmer/llvm 2.3.0
wasm 2.rs 745ms 5.2ms 19.6MB 727ms 0ms wasmedgec 0.11.0
wasm 2.rs 802ms 0.3ms 10.9MB 790ms 0ms wasmtime 1.0.0
wasm 2.rs 961ms 7.8ms 48.7MB 1007ms 10ms node 16.17.0

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go timeout 0.0ms 0.0MB 0ms 0ms go 1.19.1
go 3.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 2503ms 23ms 18.2MB 2473ms 33ms go 1.19.1
go 3.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 0-ffi.go 171ms 1.4ms 7.9MB 157ms 3ms go 1.19.1
wasm 0.rs 417ms 0.1ms 18.8MB 410ms 0ms wasmedgec 0.11.0
wasm 0.rs 418ms 1.5ms 4.9MB 410ms 0ms wasmer/llvm 2.3.0
wasm 0.rs 471ms 0.3ms 11.7MB 460ms 0ms wasmtime 1.0.0
wasm 0.rs 505ms 2.3ms 46.9MB 537ms 0ms node 16.17.0
wasm 1.rs 4460ms 4.0ms 4.9MB 4447ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 4635ms 155ms 20.2MB 4620ms 0ms wasmedgec 0.11.0
wasm 1.rs 4850ms 27ms 51.9MB 4890ms 17ms node 16.17.0
wasm 1.rs timeout 0.0ms 0.0MB 0ms 0ms wasmtime 1.0.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 0-ffi.go 56ms 0.2ms 9.6MB 43ms 0ms go 1.19.1
wasm 0.rs 107ms 0.3ms 4.8MB 97ms 0ms wasmer/llvm 2.3.0
wasm 0.rs 112ms 0.6ms 18.3MB 100ms 0ms wasmedgec 0.11.0
wasm 0.rs 124ms 0.6ms 11.0MB 110ms 0ms wasmtime 1.0.0
wasm 0.rs 206ms 2.4ms 46.7MB 230ms 7ms node 16.17.0
wasm 1.rs 1128ms 12ms 5.0MB 1107ms 0ms wasmer/llvm 2.3.0
wasm 1.rs 1142ms 0.4ms 18.5MB 1130ms 0ms wasmedgec 0.11.0
wasm 1.rs 1297ms 8.4ms 11.9MB 1283ms 0ms wasmtime 1.0.0
wasm 1.rs 1328ms 2.9ms 52.3MB 1380ms 7ms node 16.17.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 2511ms 29ms 5.4MB 4843ms 7ms go 1.19.1
wasm 2.rs 4126ms 1.0ms 19.2MB 4113ms 0ms wasmedgec 0.11.0
wasm 7.rs 4194ms 1.2ms 6.0MB 4180ms 0ms wasmer/llvm 2.3.0
wasm 7.rs 4266ms 0.6ms 18.7MB 4257ms 0ms wasmedgec 0.11.0
wasm 2.rs 4298ms 5.4ms 48.2MB 4320ms 10ms node 16.17.0
wasm 2.rs 4396ms 1.1ms 6.1MB 4380ms 0ms wasmer/llvm 2.3.0
wasm 7.rs 4506ms 11ms 52.0MB 4527ms 7ms node 16.17.0
wasm 2.rs 4534ms 12ms 11.0MB 4520ms 0ms wasmtime 1.0.0
wasm 7.rs 4610ms 2.4ms 10.9MB 4600ms 0ms wasmtime 1.0.0
go 1.go 4887ms 5.0ms 5.5MB 4870ms 3ms go 1.19.1
go 1.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 630ms 0.5ms 4.9MB 1200ms 0ms go 1.19.1
wasm 2.rs 1039ms 0.6ms 19.2MB 1027ms 0ms wasmedgec 0.11.0
wasm 7.rs 1052ms 1.1ms 6.0MB 1040ms 0ms wasmer/llvm 2.3.0
wasm 7.rs 1074ms 1.0ms 18.6MB 1063ms 0ms wasmedgec 0.11.0
wasm 2.rs 1102ms 1.1ms 6.2MB 1090ms 0ms wasmer/llvm 2.3.0
wasm 2.rs 1143ms 3.4ms 48.7MB 1177ms 3ms node 16.17.0
wasm 2.rs 1146ms 1.0ms 12.9MB 1133ms 0ms wasmtime 1.0.0
wasm 7.rs 1160ms 0.2ms 11.5MB 1147ms 0ms wasmtime 1.0.0
wasm 7.rs 1207ms 2.4ms 48.3MB 1230ms 10ms node 16.17.0
go 1.go 1229ms 3.9ms 2.9MB 1213ms 3ms go 1.19.1
go 1.go 2577ms 1.0ms 0.0MB 2560ms 0ms tinygo 0.25.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 166ms 0.9ms 4.9MB 293ms 0ms go 1.19.1
wasm 7.rs 266ms 0.6ms 4.9MB 253ms 0ms wasmer/llvm 2.3.0
wasm 2.rs 267ms 0.4ms 18.5MB 253ms 0ms wasmedgec 0.11.0
wasm 7.rs 277ms 2.1ms 19.1MB 263ms 0ms wasmedgec 0.11.0
wasm 2.rs 279ms 0.3ms 4.9MB 263ms 0ms wasmer/llvm 2.3.0
wasm 2.rs 293ms 0.3ms 9.7MB 280ms 0ms wasmtime 1.0.0
wasm 7.rs 296ms 0.3ms 9.4MB 283ms 0ms wasmtime 1.0.0
go 1.go 309ms 0.2ms 2.9MB 300ms 0ms go 1.19.1
wasm 2.rs 366ms 5.1ms 48.3MB 397ms 0ms node 16.17.0
wasm 7.rs 379ms 1.5ms 48.6MB 397ms 13ms node 16.17.0
go 1.go 648ms 0.7ms 0.0MB 637ms 0ms tinygo 0.25.0