D VS Ruby benchmarks

Current benchmark data was generated on Sat Nov 16 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
d 1.d 1714ms 10ms 312.4MB 1680ms 40ms ldc2 1.39.0
d 1.d 2690ms 19ms 314.8MB 2890ms 27ms dmd 2.109.1
ruby 1-m.rb 3083ms 2670ms 806.0MB 6603ms 543ms truffleruby 24.1.1
ruby 1.rb 3707ms 64ms 147.1MB 3593ms 93ms ruby/yjit 3.3.6
ruby 1.rb timeout 0.0ms 78.9MB 4933ms 53ms ruby 3.3.6

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 161ms 4.1ms 209.0MB 127ms 20ms ldc2 1.39.0
d 1.d 233ms 2.4ms 210.6MB 207ms 10ms dmd 2.109.1
ruby 1.rb 403ms 3.5ms 36.4MB 350ms 37ms ruby/yjit 3.3.6
ruby 1-m.rb 605ms 85ms 432.9MB 1207ms 170ms truffleruby 24.1.1
ruby 1.rb 843ms 2.6ms 36.3MB 797ms 33ms ruby 3.3.6

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 1.rb 1401ms 13ms 78.5MB 1313ms 67ms ruby/yjit 3.3.6
ruby 1.rb 1794ms 17ms 78.3MB 1690ms 87ms ruby 3.3.6
d 1.d timeout 0.0ms 16.5MB 4957ms 33ms dmd 2.109.1
d 1.d timeout 0.0ms 14.8MB 4950ms 30ms ldc2 1.39.0
ruby 1.rb timeout 0.0ms 676.8MB 4573ms 1570ms truffleruby 24.1.1

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 1.rb 166ms 0.3ms 40.4MB 120ms 30ms ruby/yjit 3.3.6
ruby 1.rb 191ms 1.2ms 40.1MB 143ms 33ms ruby 3.3.6
d 1.d 1049ms 8.0ms 8.4MB 1023ms 10ms ldc2 1.39.0
d 1.d 1313ms 9.7ms 10.8MB 1290ms 13ms dmd 2.109.1
ruby 1.rb timeout 0.0ms 708.3MB 4670ms 1473ms truffleruby 24.1.1

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 2539ms 2.5ms 8.1MB 2530ms 0ms ldc2 1.39.0
d 1.d 2922ms 4.0ms 10.3MB 2913ms 3ms dmd 2.109.1

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 441ms 1.2ms 7.9MB 430ms 0ms ldc2 1.39.0
d 1.d 535ms 5.9ms 10.1MB 523ms 0ms dmd 2.109.1

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1-im.d 393ms 36ms 5.1MB 1413ms 0ms ldc2 1.39.0
d 2-im.d 1136ms 27ms 5.1MB 4287ms 0ms ldc2 1.39.0
d 1-i.d 1481ms 0.7ms 2.8MB 1467ms 0ms ldc2 1.39.0
d 1.d 3136ms 26ms 2.8MB 3123ms 0ms ldc2 1.39.0
d 2-i.d 3223ms 4.8ms 2.8MB 3210ms 0ms ldc2 1.39.0
d 1.d 3502ms 2.1ms 4.6MB 3490ms 0ms dmd 2.109.1
d 1-im.d 4227ms 47ms 8.7MB 16457ms 0ms dmd 2.109.1
d 1-i.d timeout 0.0ms 4.5MB 4990ms 0ms dmd 2.109.1
d 2-i.d timeout 0.0ms 4.6MB 4990ms 0ms dmd 2.109.1
d 2-im.d timeout 0.0ms 6.8MB 19710ms 10ms dmd 2.109.1

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1-im.d 40ms 2.1ms 4.9MB 110ms 0ms ldc2 1.39.0
d 2-im.d 100ms 1.6ms 5.1MB 343ms 0ms ldc2 1.39.0
d 1-i.d 124ms 0.3ms 2.8MB 117ms 0ms ldc2 1.39.0
d 1.d 264ms 4.4ms 2.8MB 253ms 0ms ldc2 1.39.0
d 2-i.d 267ms 1.0ms 2.9MB 253ms 0ms ldc2 1.39.0
d 1.d 296ms 2.1ms 4.6MB 287ms 0ms dmd 2.109.1
d 1-im.d 355ms 4.0ms 6.9MB 1340ms 0ms dmd 2.109.1
d 2-im.d 531ms 2.2ms 8.8MB 1990ms 0ms dmd 2.109.1
d 1-i.d 863ms 34ms 4.5MB 853ms 0ms dmd 2.109.1
d 2-i.d 1415ms 9.9ms 4.5MB 1403ms 0ms dmd 2.109.1

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 196ms 1.6ms 31.9MB 177ms 3ms ldc2 1.39.0
d 1.d 623ms 3.2ms 48.0MB 607ms 10ms dmd 2.109.1
ruby 6.rb 2115ms 31ms 39.6MB 2087ms 17ms ruby/yjit 3.3.6
ruby 6-m.rb 2208ms 39ms 393.6MB 5667ms 377ms truffleruby 24.1.1
ruby 6.rb 3726ms 20ms 37.5MB 3690ms 27ms ruby 3.3.6

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 24ms 0.6ms 7.3MB 17ms 0ms ldc2 1.39.0
d 1.d 66ms 0.7ms 12.2MB 60ms 0ms dmd 2.109.1
ruby 6.rb 286ms 12ms 30.8MB 257ms 17ms ruby/yjit 3.3.6
ruby 6.rb 448ms 10ms 31.0MB 417ms 17ms ruby 3.3.6
ruby 6-m.rb 814ms 14ms 395.1MB 1973ms 187ms truffleruby 24.1.1

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 1.7ms 0.2ms 2.9MB 0ms 0ms ldc2 1.39.0
d 1.d 2.3ms 0.3ms 5.1MB 0ms 0ms dmd 2.109.1
ruby 1.rb 38ms 0.2ms 164.1MB 18ms 24ms truffleruby 24.1.1
ruby 1.rb 68ms 1.2ms 28.1MB 40ms 16ms ruby/yjit 3.3.6
ruby 1.rb 71ms 0.4ms 27.9MB 44ms 16ms ruby 3.3.6

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1-m.d 3.6ms 6.2ms 18.1MB 355ms 765ms ldc2 1.39.0
d 1.d 1033ms 0.9ms 22.7MB 413ms 777ms dmd 2.109.1
d 2.d 1035ms 0.6ms 25.0MB 443ms 757ms dmd 2.109.1
d 2.d timeout 0.0ms 22.1MB 333ms 780ms ldc2 1.39.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 2.d 338ms 585ms 22.0MB 50ms 140ms ldc2 1.39.0
d 1.d 1015ms 0.5ms 20.1MB 67ms 127ms ldc2 1.39.0
d 2.d 1015ms 0.4ms 24.4MB 77ms 133ms dmd 2.109.1
d 1.d 1015ms 0.5ms 24.6MB 63ms 140ms dmd 2.109.1

json-serde

Input: sample 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 2-m.d 71ms 21ms 15.5MB 70ms 50ms ldc2 1.39.0
d 2.d 241ms 1.1ms 22.6MB 240ms 10ms dmd 2.109.1
ruby 1.rb 294ms 1.9ms 46.9MB 250ms 30ms ruby/yjit 3.3.6
ruby 1.rb 297ms 3.8ms 49.1MB 247ms 37ms ruby 3.3.6
ruby 1-m.rb 4661ms 228ms 506.6MB 12150ms 317ms truffleruby 24.1.1

Input: canada 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 2.d 472ms 2.3ms 139.9MB 443ms 33ms ldc2 1.39.0
ruby 1.rb 2300ms 6.4ms 167.0MB 2183ms 97ms ruby/yjit 3.3.6
ruby 1.rb 2314ms 14ms 169.5MB 2207ms 90ms ruby 3.3.6
d 2.d 2492ms 4.3ms 157.1MB 2493ms 43ms dmd 2.109.1
ruby 1.rb timeout 0.0ms 557.8MB 13143ms 343ms truffleruby 24.1.1

knucleotide

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1-m.d 793ms 57ms 51.9MB 2410ms 20ms ldc2 1.39.0
d 1-m.d 1878ms 30ms 54.8MB 5587ms 17ms dmd 2.109.1

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1-m.d 99ms 1.8ms 42.1MB 253ms 13ms ldc2 1.39.0
d 1-m.d 203ms 2.6ms 45.9MB 587ms 13ms dmd 2.109.1

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 125ms 0.3ms 6.1MB 117ms 3ms ldc2 1.39.0
d 1.d 185ms 10ms 7.9MB 157ms 33ms dmd 2.109.1
ruby 1.rb 325ms 1.4ms 28.4MB 300ms 10ms ruby/yjit 3.3.6
ruby 1.rb 515ms 2.8ms 28.3MB 483ms 20ms ruby 3.3.6
ruby 1-m.rb 675ms 8.6ms 379.0MB 1210ms 120ms truffleruby 24.1.1

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 364ms 6.3ms 4.0MB 350ms 23ms ldc2 1.39.0
d 1.d 539ms 17ms 8.1MB 520ms 53ms dmd 2.109.1
ruby 1.rb 828ms 5.1ms 28.5MB 797ms 17ms ruby/yjit 3.3.6
ruby 1-m.rb 1237ms 106ms 424.7MB 1713ms 170ms truffleruby 24.1.1
ruby 1.rb 1402ms 4.3ms 28.3MB 1373ms 10ms ruby 3.3.6

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 55ms 1.7ms 5.9MB 43ms 0ms ldc2 1.39.0
d 1.d 79ms 0.9ms 8.2MB 70ms 0ms dmd 2.109.1
ruby 1.rb 198ms 3.7ms 28.4MB 167ms 13ms ruby/yjit 3.3.6
ruby 1.rb 293ms 2.2ms 28.3MB 257ms 17ms ruby 3.3.6
ruby 1-m.rb 531ms 4.6ms 370.3MB 1030ms 140ms truffleruby 24.1.1

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 409ms 4.3ms 7.5MB 397ms 0ms ldc2 1.39.0
d 1.d 2324ms 373ms 9.3MB 2313ms 0ms dmd 2.109.1

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 20ms 0.1ms 3.0MB 10ms 0ms ldc2 1.39.0
d 1.d 92ms 1.5ms 4.5MB 80ms 0ms dmd 2.109.1

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 979ms 4.8ms 312.5MB 940ms 40ms ldc2 1.39.0
d 1.d 1748ms 19ms 314.9MB 1883ms 40ms dmd 2.109.1
ruby 1.rb timeout 0.0ms 88.0MB 4940ms 43ms ruby 3.3.6
ruby 1.rb timeout 0.0ms 88.2MB 4913ms 70ms ruby/yjit 3.3.6
ruby 1.rb timeout 0.0ms 600.6MB 12707ms 390ms truffleruby 24.1.1

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 210ms 2.2ms 312.6MB 163ms 33ms ldc2 1.39.0
d 1.d 343ms 1.4ms 314.5MB 313ms 23ms dmd 2.109.1
ruby 1-m.rb 2264ms 138ms 544.5MB 5797ms 280ms truffleruby 24.1.1
ruby 1.rb 3024ms 14ms 47.0MB 2983ms 27ms ruby/yjit 3.3.6
ruby 1.rb 4054ms 43ms 46.5MB 4003ms 33ms ruby 3.3.6

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 2.d 361ms 0.5ms 2.9MB 350ms 0ms ldc2 1.39.0
d 1.d 361ms 1.0ms 2.9MB 350ms 0ms ldc2 1.39.0
d 1.d 680ms 2.2ms 4.6MB 670ms 0ms dmd 2.109.1
ruby 2.rb 836ms 3.2ms 328.9MB 1067ms 113ms truffleruby 24.1.1
d 2.d 2009ms 2.2ms 4.6MB 2000ms 0ms dmd 2.109.1
ruby 2.rb timeout 0.0ms 28.1MB 4973ms 13ms ruby 3.3.6
ruby 2.rb timeout 0.0ms 28.1MB 4973ms 17ms ruby/yjit 3.3.6

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 39ms 0.5ms 2.9MB 30ms 0ms ldc2 1.39.0
d 2.d 39ms 0.7ms 2.9MB 30ms 0ms ldc2 1.39.0
d 1.d 71ms 0.9ms 4.8MB 63ms 0ms dmd 2.109.1
d 2.d 203ms 0.2ms 4.6MB 190ms 0ms dmd 2.109.1
ruby 2-m.rb 320ms 5.4ms 323.3MB 570ms 93ms truffleruby 24.1.1
ruby 2.rb 1451ms 4.2ms 28.3MB 1407ms 27ms ruby/yjit 3.3.6
ruby 2.rb 2876ms 55ms 28.0MB 2843ms 13ms ruby 3.3.6

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 315ms 2.3ms 77.1MB 300ms 0ms dmd 2.109.1
d 1.d 352ms 4.4ms 43.7MB 333ms 3ms ldc2 1.39.0
d 2.d 821ms 4.2ms 47.5MB 800ms 10ms ldc2 1.39.0
d 2.d 1162ms 1.7ms 49.3MB 1143ms 3ms dmd 2.109.1
ruby 1.rb timeout 0.0ms 340.6MB 4833ms 147ms ruby 3.3.6
ruby 1.rb timeout 0.0ms 341.9MB 4837ms 147ms ruby/yjit 3.3.6
ruby 1.rb timeout 0.0ms 766.6MB 5057ms 153ms truffleruby 24.1.1

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 61ms 1.8ms 13.5MB 43ms 3ms ldc2 1.39.0
d 1.d 66ms 0.8ms 24.1MB 57ms 0ms dmd 2.109.1
d 2.d 203ms 0.8ms 15.7MB 190ms 0ms ldc2 1.39.0
d 2.d 291ms 1.3ms 17.6MB 277ms 3ms dmd 2.109.1
ruby 1-m.rb 1723ms 34ms 487.6MB 2497ms 163ms truffleruby 24.1.1
ruby 1.rb 3483ms 25ms 146.6MB 3380ms 87ms ruby/yjit 3.3.6
ruby 1.rb 4478ms 20ms 146.5MB 4387ms 70ms ruby 3.3.6

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 2410ms 8.4ms 8.0MB 2367ms 387ms ldc2 1.39.0
d 1.d 4352ms 6.4ms 10.1MB 4243ms 487ms dmd 2.109.1
ruby 1.rb timeout 0.0ms 108.5MB 4930ms 57ms ruby 3.3.6
ruby 1.rb timeout 0.0ms 108.9MB 4933ms 47ms ruby/yjit 3.3.6
ruby 1.rb timeout 0.0ms 468.5MB 13197ms 417ms truffleruby 24.1.1

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 578ms 1.6ms 8.1MB 557ms 93ms ldc2 1.39.0
d 1.d 1041ms 11ms 10.2MB 1027ms 113ms dmd 2.109.1
ruby 1-m.rb 1636ms 242ms 437.0MB 4297ms 203ms truffleruby 24.1.1
ruby 1.rb 1677ms 12ms 108.7MB 1600ms 60ms ruby/yjit 3.3.6
ruby 1.rb 1681ms 11ms 108.4MB 1607ms 60ms ruby 3.3.6

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 3.d 614ms 6.0ms 171.9MB 793ms 23ms ldc2 1.39.0
d 3.d 1345ms 56ms 174.6MB 1557ms 23ms dmd 2.109.1

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 3.d 71ms 3.4ms 25.9MB 83ms 0ms ldc2 1.39.0
d 3.d 145ms 6.4ms 26.5MB 153ms 7ms dmd 2.109.1

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 4798ms 38ms 3.9MB 4770ms 327ms ldc2 1.39.0
d 1.d timeout 0.0ms 6.6MB 5013ms 217ms dmd 2.109.1

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 1207ms 7.1ms 4.0MB 1160ms 110ms ldc2 1.39.0
d 1.d 2023ms 38ms 6.4MB 1990ms 113ms dmd 2.109.1

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 3584ms 9.1ms 4.1MB 3570ms 0ms ldc2 1.39.0
d 1.d 3665ms 31ms 5.9MB 3653ms 0ms dmd 2.109.1
ruby 4.rb timeout 0.0ms 28.1MB 4963ms 17ms ruby 3.3.6
ruby 4.rb timeout 0.0ms 28.3MB 4963ms 20ms ruby/yjit 3.3.6
ruby 4.rb timeout 0.0ms 442.6MB 5190ms 203ms truffleruby 24.1.1

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 902ms 0.5ms 3.5MB 890ms 0ms ldc2 1.39.0
d 1.d 911ms 2.1ms 5.8MB 900ms 0ms dmd 2.109.1
ruby 4.rb 4430ms 29ms 453.8MB 4663ms 227ms truffleruby 24.1.1
ruby 4.rb timeout 0.0ms 28.1MB 4967ms 17ms ruby 3.3.6
ruby 4.rb timeout 0.0ms 28.3MB 4970ms 17ms ruby/yjit 3.3.6

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
d 1.d 227ms 0.4ms 3.0MB 220ms 0ms ldc2 1.39.0
d 1.d 235ms 1.0ms 4.9MB 220ms 0ms dmd 2.109.1
ruby 4.rb 1226ms 41ms 385.4MB 1527ms 130ms truffleruby 24.1.1
ruby 4.rb timeout 0.0ms 28.1MB 4967ms 20ms ruby 3.3.6
ruby 4.rb timeout 0.0ms 28.3MB 4960ms 20ms ruby/yjit 3.3.6