Rust VS Acton 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
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
acton 1.act 3.9ms 0.2ms 8.3MB 0ms 0ms actonc 0.24.1

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

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

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

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

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

binarytrees

Input: 18

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
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
acton 1.act timeout 0.0ms 67.0MB 5963ms 77ms actonc 0.24.1

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
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
acton 1.act 829ms 36ms 12.0MB 960ms 70ms actonc 0.24.1

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

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

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
acton 1.act 273ms 7.1ms 9.0MB 240ms 77ms actonc 0.24.1
rust 2.rs 412ms 4.1ms 3.6MB 403ms 0ms rustc 1.83.0

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
acton 1.act 96ms 11ms 5.3MB 77ms 33ms actonc 0.24.1

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
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
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

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

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

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

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

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
acton 1.act 3310ms 185ms 101.9MB 3583ms 63ms actonc 0.24.1

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
acton 1.act 699ms 28ms 30.4MB 727ms 37ms actonc 0.24.1

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 1.rs 298ms 8.3ms 40.9MB 280ms 0ms rustc 1.83.0
rust 2.rs 321ms 2.9ms 6.6MB 303ms 0ms rustc 1.83.0
acton 1.act timeout 0.0ms 562.9MB 6753ms 110ms actonc 0.24.1

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
rust 2.rs 81ms 1.2ms 2.9MB 70ms 0ms rustc 1.83.0
acton 1.act 2333ms 30ms 192.4MB 2833ms 50ms actonc 0.24.1

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
acton 1-m.act 3082ms 51ms 6.6MB 2720ms 2220ms actonc 0.24.1

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
acton 1-m.act 868ms 22ms 5.6MB 723ms 653ms actonc 0.24.1

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

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

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