Nim VS Ruby benchmarks

Current benchmark data was generated on Tue Jul 01 2025, 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
nim 2.nim 819ms 29ms 34.4MB 800ms 0ms nim 2.2.4
nim 2.nim 968ms 6.2ms 35.2MB 950ms 3ms nim/clang 2.2.4
ruby 1-m.rb 4407ms 191ms 804.1MB 6390ms 450ms truffleruby 24.2.1
ruby 1.rb 4955ms 35ms 109.4MB 4853ms 87ms ruby/yjit 3.4.4
ruby 1.rb timeout 0.0ms 70.5MB 4940ms 40ms ruby 3.4.4

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 77ms 2.5ms 5.5MB 70ms 0ms nim 2.2.4
nim 2.nim 93ms 2.5ms 5.8MB 80ms 0ms nim/clang 2.2.4
ruby 1.rb 505ms 6.5ms 20.3MB 480ms 10ms ruby/yjit 3.4.4
ruby 1-m.rb 570ms 55ms 424.9MB 1133ms 167ms truffleruby 24.2.1
ruby 1.rb 967ms 21ms 19.5MB 943ms 10ms ruby 3.4.4

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 1.rb 1446ms 22ms 63.8MB 1363ms 67ms ruby/yjit 3.4.4
ruby 1.rb 1861ms 20ms 63.0MB 1787ms 63ms ruby 3.4.4
nim 1.nim timeout 0.0ms 572.1MB 2667ms 1857ms nim 2.2.4
nim 1.nim timeout 0.0ms 574.6MB 2610ms 1913ms nim/clang 2.2.4
ruby 1.rb timeout 0.0ms 327.3MB 4810ms 1417ms truffleruby 24.2.1

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 1.rb 155ms 1.3ms 25.6MB 127ms 17ms ruby/yjit 3.4.4
ruby 1.rb 184ms 1.1ms 25.0MB 157ms 17ms ruby 3.4.4
nim 1.nim 4108ms 3.9ms 518.6MB 2127ms 1553ms nim/clang 2.2.4
nim 1.nim 4147ms 34ms 519.4MB 2150ms 1567ms nim 2.2.4
ruby 1.rb timeout 0.0ms 351.7MB 4637ms 1527ms truffleruby 24.2.1

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 189ms 1.3ms 1.5MB 180ms 0ms nim 2.2.4
nim 2.nim 242ms 1.4ms 1.8MB 230ms 0ms nim/clang 2.2.4
nim 1.nim 539ms 0.9ms 1.8MB 447ms 80ms nim/clang 2.2.4
nim 1.nim 562ms 2.0ms 1.5MB 467ms 77ms nim 2.2.4
ruby 6.rb 2079ms 63ms 23.0MB 2053ms 10ms ruby/yjit 3.4.4
ruby 6-m.rb 2218ms 75ms 408.9MB 5653ms 337ms truffleruby 24.2.1
ruby 6.rb 3700ms 18ms 22.4MB 3673ms 10ms ruby 3.4.4

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 21ms 1.0ms 1.5MB 10ms 0ms nim 2.2.4
nim 2.nim 26ms 0.3ms 1.6MB 20ms 0ms nim/clang 2.2.4
nim 1.nim 56ms 0.7ms 1.9MB 40ms 7ms nim/clang 2.2.4
nim 1.nim 58ms 0.5ms 1.5MB 43ms 0ms nim 2.2.4
ruby 6.rb 257ms 1.5ms 15.2MB 240ms 3ms ruby/yjit 3.4.4
ruby 6.rb 420ms 1.2ms 14.4MB 403ms 7ms ruby 3.4.4
ruby 6-m.rb 848ms 18ms 388.9MB 2133ms 180ms truffleruby 24.2.1

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 1.0ms 0.0ms 1.5MB 0ms 0ms nim 2.2.4
nim 1.nim 1.1ms 0.0ms 1.8MB 0ms 0ms nim/clang 2.2.4
ruby 1.rb 35ms 1.1ms 141.3MB 16ms 24ms truffleruby 24.2.1
ruby 1.rb 52ms 0.9ms 12.8MB 40ms 0ms ruby 3.4.4
ruby 1.rb 52ms 1.2ms 12.9MB 40ms 2ms ruby/yjit 3.4.4

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 111ms 2.3ms 1.9MB 103ms 0ms nim/clang 2.2.4
nim 2.nim 114ms 1.1ms 1.6MB 110ms 0ms nim 2.2.4
ruby 1.rb 342ms 2.8ms 13.5MB 323ms 0ms ruby/yjit 3.4.4
ruby 1.rb 526ms 4.3ms 12.9MB 507ms 3ms ruby 3.4.4
ruby 1-m.rb 707ms 30ms 372.7MB 1240ms 147ms truffleruby 24.2.1
nim 1.nim timeout 0.0ms 1.3MB 4990ms 0ms nim 2.2.4
nim 1.nim timeout 0.0ms 1.5MB 4990ms 0ms nim/clang 2.2.4

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 326ms 1.8ms 1.6MB 317ms 0ms nim/clang 2.2.4
nim 2.nim 335ms 2.3ms 1.6MB 327ms 0ms nim 2.2.4
ruby 1.rb 913ms 4.6ms 13.5MB 897ms 0ms ruby/yjit 3.4.4
ruby 1-m.rb 1253ms 6.5ms 411.5MB 1750ms 167ms truffleruby 24.2.1
ruby 1.rb 1478ms 32ms 12.9MB 1457ms 7ms ruby 3.4.4
nim 1.nim timeout 0.0ms 1.3MB 4990ms 0ms nim 2.2.4
nim 1.nim timeout 0.0ms 1.5MB 4990ms 0ms nim/clang 2.2.4

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 49ms 0.7ms 1.5MB 40ms 0ms nim/clang 2.2.4
nim 2.nim 51ms 2.1ms 1.5MB 43ms 0ms nim 2.2.4
ruby 1.rb 198ms 2.3ms 13.5MB 180ms 10ms ruby/yjit 3.4.4
ruby 1.rb 289ms 3.7ms 12.8MB 270ms 7ms ruby 3.4.4
nim 1.nim 477ms 2.9ms 1.3MB 470ms 0ms nim 2.2.4
nim 1.nim 486ms 13ms 1.5MB 477ms 0ms nim/clang 2.2.4
ruby 1-m.rb 530ms 42ms 354.3MB 1040ms 137ms truffleruby 24.2.1

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 387ms 1.2ms 4.8MB 380ms 0ms nim/clang 2.2.4
nim 1.nim 578ms 3.9ms 4.5MB 567ms 0ms nim 2.2.4

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 19ms 0.4ms 1.9MB 10ms 0ms nim/clang 2.2.4
nim 1.nim 26ms 0.6ms 1.6MB 20ms 0ms nim 2.2.4

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 550ms 7.5ms 34.9MB 533ms 7ms nim 2.2.4
nim 1.nim 626ms 13ms 35.2MB 607ms 3ms nim/clang 2.2.4
ruby 1-m.rb 4269ms 456ms 556.4MB 10877ms 377ms truffleruby 24.2.1
ruby 1.rb timeout 0.0ms 93.5MB 4947ms 40ms ruby 3.4.4
ruby 1.rb timeout 0.0ms 97.2MB 4933ms 50ms ruby/yjit 3.4.4

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 117ms 1.4ms 9.6MB 107ms 0ms nim 2.2.4
nim 1.nim 133ms 1.2ms 9.9MB 120ms 0ms nim/clang 2.2.4
ruby 1-m.rb 1985ms 41ms 547.4MB 5130ms 257ms truffleruby 24.2.1
ruby 1.rb 3266ms 10ms 38.3MB 3233ms 20ms ruby/yjit 3.4.4
ruby 1.rb 4383ms 23ms 37.6MB 4340ms 27ms ruby 3.4.4

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 319ms 1.6ms 1.8MB 310ms 0ms nim 2.2.4
nim 2.nim 341ms 1.3ms 2.0MB 330ms 0ms nim/clang 2.2.4
ruby 2.rb 835ms 11ms 315.3MB 1080ms 117ms truffleruby 24.2.1
ruby 2.rb timeout 0.0ms 12.8MB 4983ms 3ms ruby 3.4.4
ruby 2.rb timeout 0.0ms 13.5MB 4980ms 7ms ruby/yjit 3.4.4

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 35ms 0.5ms 1.8MB 30ms 0ms nim 2.2.4
nim 2.nim 37ms 0.7ms 2.0MB 30ms 0ms nim/clang 2.2.4
ruby 2-m.rb 323ms 13ms 309.9MB 563ms 123ms truffleruby 24.2.1
ruby 2.rb 1026ms 2.7ms 13.5MB 1007ms 7ms ruby/yjit 3.4.4
ruby 2.rb 2901ms 120ms 12.8MB 2887ms 0ms ruby 3.4.4

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 281ms 9.2ms 41.5MB 270ms 0ms nim 2.2.4
nim 1.nim 314ms 3.5ms 41.8MB 303ms 0ms nim/clang 2.2.4
ruby 1.rb timeout 0.0ms 325.3MB 4850ms 137ms ruby 3.4.4
ruby 1.rb timeout 0.0ms 327.0MB 4857ms 130ms ruby/yjit 3.4.4
ruby 1.rb timeout 0.0ms 731.6MB 5057ms 170ms truffleruby 24.2.1

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 51ms 1.7ms 11.5MB 40ms 0ms nim 2.2.4
nim 1.nim 64ms 3.6ms 11.8MB 53ms 0ms nim/clang 2.2.4
ruby 1-m.rb 1708ms 13ms 494.0MB 2480ms 177ms truffleruby 24.2.1
ruby 1.rb 3451ms 53ms 131.8MB 3363ms 73ms ruby/yjit 3.4.4
ruby 1.rb 4587ms 13ms 131.1MB 4493ms 77ms ruby 3.4.4

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 1641ms 6.1ms 151.9MB 1607ms 20ms nim/clang 2.2.4
nim 1.nim 1674ms 9.9ms 152.1MB 1640ms 20ms nim 2.2.4

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 173ms 1.8ms 16.8MB 160ms 0ms nim/clang 2.2.4
nim 1.nim 177ms 3.9ms 16.5MB 163ms 0ms nim 2.2.4

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 3588ms 2.7ms 1.6MB 3580ms 0ms nim/clang 2.2.4
nim 1.nim 3609ms 14ms 1.4MB 3603ms 0ms nim 2.2.4
ruby 4.rb timeout 0.0ms 12.9MB 4980ms 0ms ruby 3.4.4
ruby 4.rb timeout 0.0ms 13.5MB 4983ms 3ms ruby/yjit 3.4.4
ruby 4.rb timeout 0.0ms 449.5MB 5163ms 247ms truffleruby 24.2.1

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 899ms 0.7ms 1.5MB 890ms 0ms nim/clang 2.2.4
nim 1.nim 904ms 2.9ms 1.3MB 893ms 0ms nim 2.2.4
ruby 4.rb 4909ms 38ms 442.4MB 5200ms 217ms truffleruby 24.2.1
ruby 4.rb timeout 0.0ms 12.9MB 4980ms 0ms ruby 3.4.4
ruby 4.rb timeout 0.0ms 13.5MB 4983ms 3ms ruby/yjit 3.4.4

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 226ms 0.3ms 1.5MB 220ms 0ms nim/clang 2.2.4
nim 1.nim 229ms 0.9ms 1.3MB 220ms 0ms nim 2.2.4
ruby 4.rb 1458ms 5.9ms 388.7MB 1803ms 150ms truffleruby 24.2.1
ruby 4.rb timeout 0.0ms 12.9MB 4980ms 0ms ruby 3.4.4
ruby 4.rb timeout 0.0ms 13.6MB 4983ms 0ms ruby/yjit 3.4.4