Rust VS Chapel 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
chapel 1.chpl 17ms 2.0ms 32.8MB 10ms 0ms chpl 1.31.0

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
chapel 2.chpl 329ms 2.7ms 32.9MB 317ms 3ms 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.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
chapel 2.chpl 51ms 0.3ms 32.8MB 40ms 3ms chpl 1.31.0

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
chapel 1-m.chpl 1923ms 22ms 32.9MB 3807ms 3ms chpl 1.31.0
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
chapel 1.chpl 3722ms 3.1ms 32.8MB 3713ms 0ms chpl 1.31.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
chapel 1-m.chpl 497ms 2.1ms 32.9MB 957ms 0ms chpl 1.31.0
rust 7.rs 531ms 2.9ms 1.8MB 520ms 0ms rustc 1.83.0
chapel 1.chpl 946ms 5.0ms 32.8MB 937ms 7ms chpl 1.31.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
chapel 1-m.chpl 141ms 0.2ms 32.9MB 247ms 0ms chpl 1.31.0
chapel 1.chpl 254ms 2.0ms 32.8MB 243ms 0ms chpl 1.31.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
chapel 4.chpl 1953ms 6.1ms 66.3MB 1937ms 7ms chpl 1.31.0
chapel 3.chpl 2024ms 5.9ms 66.3MB 2007ms 7ms chpl 1.31.0

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
chapel 4.chpl 191ms 1.6ms 36.4MB 177ms 3ms chpl 1.31.0
chapel 3.chpl 194ms 1.4ms 36.4MB 187ms 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 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
chapel 1-m.chpl 2294ms 56ms 508.1MB 4467ms 67ms chpl 1.31.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
chapel 1-m.chpl 189ms 0.8ms 418.9MB 300ms 37ms chpl 1.31.0

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 79ms 0.3ms 36.5MB 67ms 3ms chpl 1.31.0
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

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
chapel 1.chpl 40ms 0.5ms 34.5MB 30ms 0ms chpl 1.31.0
rust 2.rs 74ms 0.1ms 3.0MB 63ms 0ms rustc 1.83.0

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
chapel 5-m.chpl 112ms 0.8ms 32.4MB 197ms 0ms chpl 1.31.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
chapel 5.chpl 28ms 0.3ms 32.4MB 17ms 3ms chpl 1.31.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
chapel 3-m.chpl 747ms 2.4ms 90.9MB 1403ms 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 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
chapel 3-m.chpl 121ms 0.7ms 80.9MB 200ms 3ms chpl 1.31.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

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

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

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 450ms 0.3ms 32.4MB 440ms 0ms chpl 1.31.0
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

Input: 4000

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

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
chapel 3.chpl 1393ms 10ms 224.2MB 1353ms 33ms chpl 1.31.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
chapel 3.chpl 169ms 1.9ms 52.9MB 150ms 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 117ms 3.1ms 1.9MB 110ms 0ms rustc 1.83.0
chapel 1.chpl 1184ms 7.2ms 33.0MB 1177ms 0ms chpl 1.31.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
chapel 1.chpl 319ms 14ms 33.0MB 313ms 0ms chpl 1.31.0
rust 1.rs 355ms 5.5ms 1.9MB 343ms 0ms rustc 1.83.0