Rust VS V benchmarks

Current benchmark data was generated on Mon Dec 30 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.)

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
v 1.v 1.1ms 0.0ms 1.4MB 0ms 0ms v/clang 0.4.9
rust 1.rs 1.2ms 0.0ms 1.9MB 0ms 0ms rustc 1.85.0-nightly
rust 1.rs 1.3ms 0.1ms 1.8MB 0ms 0ms rustc 1.83.0
v 1.v 1.3ms 0.1ms 1.9MB 0ms 0ms v/clang+gc 0.4.9

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 9.rs 252ms 9.1ms 4.8MB 240ms 0ms rustc 1.85.0-nightly
rust 8.rs 307ms 1.2ms 4.9MB 297ms 0ms rustc 1.83.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 9.rs 13ms 0.7ms 2.0MB 10ms 0ms rustc 1.85.0-nightly
rust 8.rs 15ms 0.1ms 2.0MB 10ms 0ms rustc 1.83.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 4-i.rs 180ms 29ms 1.8MB 170ms 0ms rustc 1.83.0
rust 7-i.rs 236ms 1.2ms 1.8MB 223ms 0ms rustc 1.83.0
rust 1.rs 238ms 0.9ms 1.8MB 230ms 0ms rustc 1.83.0
rust 2.rs 278ms 0.4ms 1.8MB 270ms 0ms rustc 1.83.0
rust 3.rs 280ms 0.1ms 1.9MB 270ms 0ms rustc 1.85.0-nightly
v 1.v 309ms 0.5ms 1.6MB 300ms 0ms v/clang 0.4.9
v 1.v 311ms 1.8ms 2.3MB 300ms 0ms v/clang+gc 0.4.9

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 4-i.rs 18ms 0.1ms 1.8MB 10ms 0ms rustc 1.83.0
rust 7-i.rs 26ms 0.2ms 1.8MB 17ms 0ms rustc 1.83.0
rust 1.rs 26ms 0.3ms 1.8MB 17ms 0ms rustc 1.83.0
rust 2.rs 30ms 0.2ms 1.8MB 20ms 0ms rustc 1.83.0
rust 3.rs 30ms 0.2ms 1.8MB 20ms 0ms rustc 1.85.0-nightly
v 1.v 33ms 0.0ms 1.6MB 23ms 0ms v/clang 0.4.9
v 1.v 33ms 0.7ms 2.3MB 23ms 0ms v/clang+gc 0.4.9

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 8-m.rs 496ms 0.3ms 4.6MB 1903ms 3ms rustc 1.85.0-nightly
rust 7-m.rs 497ms 0.4ms 4.2MB 1913ms 7ms rustc 1.83.0
rust 8.rs 1007ms 0.3ms 2.4MB 993ms 0ms rustc 1.85.0-nightly
rust 2-m.rs 1948ms 0.9ms 6.2MB 7640ms 7ms rustc 1.83.0
rust 7.rs 2100ms 7.2ms 1.9MB 2090ms 0ms rustc 1.83.0
rust 2.rs 4189ms 4.1ms 2.0MB 4177ms 0ms rustc 1.83.0
v 1.v timeout 0.0ms 1.6MB 4990ms 0ms v/clang 0.4.9
v 1.v timeout 0.0ms 2.8MB 4990ms 0ms v/clang+gc 0.4.9

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 8-m.rs 128ms 0.2ms 4.2MB 450ms 13ms rustc 1.85.0-nightly
rust 7-m.rs 128ms 0.1ms 4.1MB 473ms 0ms rustc 1.83.0
rust 8.rs 254ms 0.5ms 2.3MB 247ms 0ms rustc 1.85.0-nightly
rust 2-m.rs 492ms 2.9ms 4.1MB 1880ms 0ms rustc 1.83.0
rust 7.rs 531ms 2.9ms 1.8MB 520ms 0ms rustc 1.83.0
rust 2.rs 1048ms 0.7ms 1.9MB 1040ms 0ms rustc 1.83.0
v 1.v 1277ms 7.3ms 1.5MB 1267ms 0ms v/clang 0.4.9
v 1.v 1305ms 2.8ms 2.5MB 1297ms 0ms v/clang+gc 0.4.9

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 8-m.rs 35ms 0.4ms 4.2MB 113ms 0ms rustc 1.85.0-nightly
rust 7-m.rs 36ms 0.4ms 4.1MB 107ms 3ms rustc 1.83.0
rust 8.rs 66ms 0.3ms 2.1MB 57ms 0ms rustc 1.85.0-nightly
rust 2-m.rs 128ms 0.5ms 4.1MB 463ms 0ms rustc 1.83.0
rust 7.rs 135ms 2.7ms 1.8MB 127ms 0ms rustc 1.83.0
rust 2.rs 264ms 0.6ms 1.9MB 250ms 0ms rustc 1.83.0
v 1.v 323ms 1.0ms 1.5MB 310ms 0ms v/clang 0.4.9
v 1.v 333ms 0.1ms 2.5MB 323ms 0ms v/clang+gc 0.4.9

binarytrees

Input: 18

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
v 1.v 769ms 31ms 28.9MB 753ms 3ms v/clang+gc 0.4.9
rust 4.rs 1245ms 9.2ms 33.8MB 1227ms 3ms rustc 1.83.0
rust 5.rs 1324ms 7.0ms 33.8MB 1297ms 10ms rustc 1.83.0
rust 3.rs 1436ms 25ms 49.8MB 1403ms 17ms rustc 1.83.0
v 1.v 2146ms 3.2ms 2086.6MB 1237ms 890ms v/clang 0.4.9

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
v 1.v 68ms 0.3ms 4.6MB 60ms 0ms v/clang+gc 0.4.9
rust 4.rs 118ms 2.7ms 5.8MB 107ms 0ms rustc 1.83.0
rust 5.rs 126ms 0.6ms 5.8MB 120ms 0ms rustc 1.83.0
rust 3.rs 141ms 4.7ms 7.8MB 127ms 0ms rustc 1.83.0
v 1.v 209ms 2.0ms 198.0MB 123ms 73ms v/clang 0.4.9

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 5-m.rs 470ms 226ms 7.6MB 1753ms 53ms rustc 1.83.0
rust 3-m.rs 539ms 55ms 11.1MB 2013ms 73ms rustc 1.83.0
rust 1-m.rs 956ms 11ms 12.4MB 3470ms 257ms rustc 1.83.0
rust 3.rs 1141ms 20ms 9.3MB 1100ms 27ms rustc 1.83.0
rust 4.rs 1902ms 10ms 7.4MB 1887ms 3ms rustc 1.83.0
v 1.v timeout 0.0ms 22.6MB 9157ms 10407ms v/clang 0.4.9
v 1.v timeout 0.0ms 22.4MB 9853ms 9697ms v/clang+gc 0.4.9

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 5-m.rs 51ms 4.2ms 5.3MB 150ms 10ms rustc 1.83.0
rust 3-m.rs 53ms 2.6ms 6.3MB 153ms 17ms rustc 1.83.0
rust 3.rs 74ms 1.0ms 4.0MB 60ms 0ms rustc 1.83.0
rust 1-m.rs 87ms 9.5ms 7.8MB 253ms 43ms rustc 1.83.0
rust 4.rs 116ms 1.8ms 3.3MB 107ms 0ms rustc 1.83.0
v 1-m.v 2563ms 299ms 20.3MB 4827ms 5190ms v/clang+gc 0.4.9
v 1-m.v 2873ms 231ms 15.7MB 5180ms 6013ms v/clang 0.4.9

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 115ms 0.4ms 3.6MB 100ms 0ms rustc 1.83.0
rust 2.rs 412ms 4.1ms 3.6MB 403ms 0ms rustc 1.83.0
v 1.v timeout 0.0ms 23.3MB 4980ms 3ms v/clang+gc 0.4.9

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 34ms 1.7ms 2.9MB 27ms 0ms rustc 1.83.0
rust 2.rs 74ms 0.1ms 3.0MB 63ms 0ms rustc 1.83.0
v 1.v timeout 0.0ms 13.8MB 4990ms 0ms v/clang+gc 0.4.9

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 3-im.rs 411ms 1.3ms 4.0MB 1573ms 0ms rustc 1.83.0
rust 5-m.rs 570ms 8.3ms 4.0MB 2173ms 0ms rustc 1.83.0
rust 2-im.rs 626ms 1.8ms 4.0MB 2390ms 0ms rustc 1.83.0
rust 1-m.rs 982ms 5.3ms 8.0MB 3763ms 0ms rustc 1.83.0
rust 3-i.rs 1490ms 1.7ms 1.9MB 1480ms 0ms rustc 1.83.0
rust 2-i.rs 1753ms 3.8ms 1.8MB 1743ms 0ms rustc 1.83.0
v 1.v 2186ms 5.5ms 1.9MB 2173ms 0ms v/clang+gc 0.4.9
v 1.v 2191ms 1.3ms 1.1MB 2180ms 0ms v/clang 0.4.9
rust 1.rs 2661ms 17ms 1.8MB 2650ms 0ms rustc 1.83.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 3-im.rs 38ms 0.1ms 4.0MB 120ms 0ms rustc 1.83.0
rust 5-m.rs 54ms 2.0ms 4.0MB 173ms 0ms rustc 1.83.0
rust 2-im.rs 60ms 2.3ms 6.0MB 200ms 0ms rustc 1.83.0
rust 1-m.rs 88ms 2.0ms 6.0MB 303ms 0ms rustc 1.83.0
rust 3-i.rs 125ms 0.3ms 1.9MB 117ms 0ms rustc 1.83.0
rust 2-i.rs 149ms 0.6ms 1.8MB 140ms 0ms rustc 1.83.0
v 1.v 186ms 1.9ms 1.1MB 170ms 0ms v/clang 0.4.9
v 1.v 187ms 1.8ms 1.9MB 180ms 0ms v/clang+gc 0.4.9
rust 1.rs 223ms 2.6ms 1.8MB 210ms 0ms rustc 1.83.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 5c-m.rs 89ms 1.0ms 8.3MB 247ms 0ms rustc 1.83.0
rust 5-m.rs 98ms 1.1ms 4.8MB 323ms 3ms rustc 1.83.0
rust 1c.rs 162ms 0.9ms 1.9MB 150ms 0ms rustc 1.83.0
rust 1.rs 196ms 0.6ms 1.9MB 180ms 0ms rustc 1.83.0
v 1.v 500ms 1.4ms 1.3MB 483ms 0ms v/clang 0.4.9
v 1.v 538ms 4.2ms 2.1MB 523ms 0ms v/clang+gc 0.4.9

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 5c-m.rs 16ms 0.5ms 4.8MB 20ms 0ms rustc 1.83.0
rust 5-m.rs 17ms 1.2ms 4.8MB 27ms 0ms rustc 1.83.0
rust 1c.rs 19ms 0.3ms 1.9MB 10ms 0ms rustc 1.83.0
rust 1.rs 22ms 0.1ms 1.9MB 10ms 0ms rustc 1.83.0
v 1.v 52ms 0.3ms 1.3MB 43ms 0ms v/clang 0.4.9
v 1.v 57ms 2.4ms 2.1MB 50ms 0ms v/clang+gc 0.4.9

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1-m.rs 283ms 65ms 45.2MB 110ms 320ms rustc 1.83.0
rust 2-http2.rs 333ms 40ms 59.8MB 523ms 420ms rustc 1.83.0
rust 1-http2.rs 417ms 64ms 66.6MB 580ms 613ms rustc 1.83.0
rust 2-m.rs 453ms 57ms 75.7MB 217ms 810ms rustc 1.83.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 71ms 14ms 16.6MB 7ms 80ms rustc 1.83.0
rust 2-m.rs 121ms 5.1ms 35.6MB 43ms 173ms rustc 1.83.0
rust 1-http2.rs 186ms 23ms 28.2MB 303ms 177ms rustc 1.83.0
rust 2-http2.rs 204ms 18ms 34.0MB 410ms 163ms rustc 1.83.0

json-serde

Input: sample 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 5-i.rs 30ms 1.2ms 9.8MB 20ms 0ms rustc 1.83.0
rust 4-i.rs 33ms 2.7ms 7.9MB 20ms 0ms rustc 1.83.0
rust 3.rs 62ms 1.7ms 33.8MB 40ms 10ms rustc 1.83.0
rust 2.rs 62ms 0.1ms 35.5MB 40ms 10ms rustc 1.83.0
rust 1.rs 102ms 1.9ms 69.3MB 57ms 33ms rustc 1.83.0

Input: canada 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 5-i.rs 208ms 1.9ms 52.8MB 183ms 7ms rustc 1.83.0
rust 4-i.rs 265ms 3.2ms 54.5MB 207ms 47ms rustc 1.83.0
rust 3.rs 412ms 1.5ms 238.3MB 300ms 97ms rustc 1.83.0
rust 2.rs 415ms 3.6ms 237.7MB 300ms 97ms rustc 1.83.0
rust 1.rs 694ms 8.1ms 551.8MB 440ms 237ms rustc 1.83.0

knucleotide

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 8-m.rs 225ms 9.9ms 30.6MB 663ms 3ms rustc 1.83.0
rust 8.rs 471ms 6.3ms 24.0MB 450ms 7ms rustc 1.83.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 8-m.rs 33ms 1.6ms 16.7MB 60ms 3ms rustc 1.83.0
rust 8.rs 61ms 1.4ms 11.4MB 43ms 0ms rustc 1.83.0

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 0-unsafe.rs 32ms 2.1ms 1.9MB 23ms 0ms rustc 1.83.0
rust 1.rs 46ms 1.5ms 2.0MB 37ms 0ms rustc 1.83.0
v 1.v 241ms 4.0ms 1.3MB 227ms 0ms v/clang 0.4.9
v 1.v 258ms 6.4ms 2.1MB 247ms 0ms v/clang+gc 0.4.9

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 0-unsafe.rs 144ms 14ms 1.9MB 133ms 0ms rustc 1.83.0
rust 1.rs 187ms 10ms 2.0MB 177ms 0ms rustc 1.83.0
v 1.v 709ms 3.2ms 1.3MB 697ms 0ms v/clang 0.4.9
v 1.v 765ms 2.4ms 2.1MB 753ms 0ms v/clang+gc 0.4.9

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 0-unsafe.rs 23ms 0.8ms 1.9MB 10ms 0ms rustc 1.83.0
rust 1.rs 29ms 2.3ms 1.9MB 20ms 0ms rustc 1.83.0
v 1.v 89ms 0.4ms 1.3MB 80ms 0ms v/clang 0.4.9
v 1.v 99ms 0.8ms 2.1MB 90ms 0ms v/clang+gc 0.4.9

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 699ms 10ms 33.8MB 673ms 10ms rustc 1.83.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 148ms 0.5ms 9.8MB 140ms 0ms rustc 1.83.0

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
v 1.v 295ms 10ms 40.4MB 277ms 0ms v/clang 0.4.9
rust 1.rs 298ms 8.3ms 40.9MB 280ms 0ms rustc 1.83.0
v 1.v 310ms 5.8ms 60.6MB 297ms 0ms v/clang+gc 0.4.9
rust 2.rs 321ms 2.9ms 6.6MB 303ms 0ms rustc 1.83.0
v 2.v 332ms 2.1ms 6.9MB 320ms 0ms v/clang+gc 0.4.9
v 2.v 332ms 3.8ms 6.1MB 320ms 0ms v/clang 0.4.9

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 60ms 1.9ms 11.6MB 47ms 0ms rustc 1.83.0
v 1.v 60ms 1.9ms 11.9MB 50ms 0ms v/clang+gc 0.4.9
v 1.v 61ms 2.4ms 11.0MB 50ms 0ms v/clang 0.4.9
rust 2.rs 81ms 1.2ms 2.9MB 70ms 0ms rustc 1.83.0
v 2.v 82ms 1.5ms 2.4MB 73ms 0ms v/clang 0.4.9
v 2.v 83ms 1.6ms 3.1MB 70ms 0ms v/clang+gc 0.4.9

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 1567ms 4.0ms 2.7MB 1343ms 203ms rustc 1.83.0
rust 2.rs 1706ms 7.7ms 2.8MB 1617ms 73ms rustc 1.83.0
v 2.v timeout 0.0ms 7.8MB 4973ms 10ms v/clang+gc 0.4.9

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 324ms 4.3ms 2.4MB 290ms 20ms rustc 1.83.0
rust 2.rs 381ms 3.5ms 2.5MB 367ms 0ms rustc 1.83.0
v 2.v 809ms 37ms 2.6MB 793ms 0ms v/clang+gc 0.4.9

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 7.rs 434ms 2.7ms 78.4MB 433ms 20ms rustc 1.83.0
v 1.v timeout 0.0ms 83.1MB 4973ms 7ms v/clang+gc 0.4.9

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 7.rs 50ms 0.2ms 11.4MB 40ms 3ms rustc 1.83.0
v 1.v 3306ms 71ms 26.0MB 3293ms 0ms v/clang+gc 0.4.9

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 0.rs 117ms 3.1ms 1.9MB 110ms 0ms rustc 1.83.0
rust 1.rs 1406ms 12ms 2.0MB 1397ms 0ms rustc 1.83.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 0.rs 33ms 1.6ms 1.9MB 23ms 0ms rustc 1.83.0
rust 1.rs 355ms 5.5ms 1.9MB 343ms 0ms rustc 1.83.0