Chapel 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
chapel 4.chpl 1855ms 24ms 66.3MB 1843ms 3ms chpl 1.31.0
chapel 3.chpl 1925ms 21ms 66.3MB 1917ms 0ms chpl 1.31.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
chapel 3.chpl 183ms 2.0ms 36.3MB 173ms 0ms chpl 1.31.0
chapel 4.chpl 185ms 4.8ms 36.4MB 180ms 0ms chpl 1.31.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
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
chapel 1-m.chpl 2149ms 35ms 527.8MB 4187ms 63ms chpl 1.31.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
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
chapel 1-m.chpl 183ms 18ms 488.7MB 287ms 40ms chpl 1.31.0

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 75ms 2.3ms 36.4MB 70ms 0ms chpl 1.31.0
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

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
chapel 1.chpl 38ms 0.3ms 34.5MB 27ms 7ms chpl 1.31.0
rust 2.rs 71ms 1.3ms 3.0MB 60ms 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 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
chapel 5-m.chpl 110ms 2.4ms 32.4MB 183ms 3ms chpl 1.31.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

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
chapel 5.chpl 27ms 0.7ms 32.4MB 23ms 0ms chpl 1.31.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
chapel 1.chpl 17ms 1.9ms 32.8MB 10ms 0ms chpl 1.31.0

knucleotide

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 8-m.rs 228ms 4.6ms 30.5MB 650ms 10ms rustc 1.83.0
rust 8.rs 472ms 16ms 23.8MB 447ms 10ms rustc 1.83.0
chapel 3-m.chpl 719ms 7.0ms 102.9MB 1350ms 7ms chpl 1.31.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 8-m.rs 30ms 2.5ms 15.8MB 53ms 0ms rustc 1.83.0
rust 8.rs 58ms 2.1ms 11.5MB 43ms 0ms rustc 1.83.0
chapel 3-m.chpl 118ms 3.2ms 81.0MB 200ms 0ms chpl 1.31.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
chapel 2.chpl 310ms 1.1ms 32.8MB 300ms 0ms chpl 1.31.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
chapel 2.chpl 49ms 1.1ms 32.9MB 43ms 0ms chpl 1.31.0

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 428ms 1.0ms 34.2MB 417ms 0ms chpl 1.31.0
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

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 115ms 2.9ms 34.4MB 103ms 7ms chpl 1.31.0
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

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 7.rs 434ms 9.7ms 80.4MB 450ms 17ms rustc 1.83.0
chapel 3.chpl 1315ms 8.8ms 224.1MB 1263ms 40ms chpl 1.31.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
rust 7.rs 48ms 0.4ms 11.4MB 40ms 3ms rustc 1.83.0
chapel 3.chpl 161ms 3.9ms 52.9MB 140ms 10ms chpl 1.31.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
chapel 1.chpl 1147ms 46ms 33.1MB 1137ms 0ms chpl 1.31.0
rust 1.rs 1337ms 7.5ms 1.9MB 1330ms 0ms rustc 1.83.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
chapel 1.chpl 297ms 3.2ms 33.0MB 287ms 3ms chpl 1.31.0
rust 1.rs 345ms 5.2ms 1.9MB 333ms 0ms rustc 1.83.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
chapel 1-m.chpl 1822ms 10.0ms 32.9MB 3613ms 0ms chpl 1.31.0
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
chapel 1.chpl 3541ms 31ms 32.8MB 3530ms 3ms chpl 1.31.0
rust 2.rs 3948ms 11ms 2.0MB 3937ms 0ms rustc 1.83.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
chapel 1-m.chpl 467ms 2.3ms 32.8MB 897ms 3ms chpl 1.31.0
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
chapel 1.chpl 893ms 7.1ms 32.8MB 887ms 0ms chpl 1.31.0
rust 2.rs 1001ms 10ms 1.9MB 987ms 0ms rustc 1.83.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
chapel 1-m.chpl 132ms 0.7ms 32.8MB 230ms 0ms chpl 1.31.0
rust 7.rs 135ms 1.1ms 1.8MB 123ms 0ms rustc 1.83.0
chapel 1.chpl 241ms 1.9ms 32.9MB 230ms 3ms chpl 1.31.0
rust 2.rs 256ms 5.0ms 1.9MB 247ms 0ms rustc 1.83.0