Perl VS Ruby benchmarks

Current benchmark data was generated on Mon Jun 23 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
ruby 1.rb 4905ms 47ms 110.1MB 4803ms 87ms ruby/yjit 3.4.4
perl 1.pl timeout 0.0ms 77.8MB 4963ms 27ms perl 5.40.2
ruby 1.rb timeout 0.0ms 70.5MB 4950ms 37ms ruby 3.4.4
ruby 1.rb timeout 0.0ms 757.2MB 6760ms 690ms truffleruby 24.2.1

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 1.rb 500ms 4.2ms 20.3MB 477ms 10ms ruby/yjit 3.4.4
ruby 1-m.rb 571ms 43ms 418.8MB 1113ms 167ms truffleruby 24.2.1
ruby 1.rb 948ms 9.8ms 19.5MB 927ms 10ms ruby 3.4.4
perl 1.pl 1824ms 20ms 14.4MB 1807ms 3ms perl 5.40.2

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 6.rb 2028ms 6.4ms 23.0MB 2003ms 10ms ruby/yjit 3.4.4
ruby 6-m.rb 2281ms 208ms 390.3MB 5913ms 350ms truffleruby 24.2.1
perl 1.pl 3560ms 16ms 10.9MB 3543ms 0ms perl 5.40.2
ruby 6.rb 3700ms 25ms 22.4MB 3677ms 10ms ruby 3.4.4

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 6.rb 302ms 71ms 15.2MB 287ms 3ms ruby/yjit 3.4.4
perl 1.pl 367ms 3.4ms 6.6MB 353ms 0ms perl 5.40.2
ruby 6.rb 419ms 3.5ms 14.5MB 400ms 3ms ruby 3.4.4
ruby 6-m.rb 825ms 52ms 388.8MB 2063ms 170ms truffleruby 24.2.1

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
perl 1.pl 2.6ms 0.2ms 5.1MB 0ms 0ms perl 5.40.2
ruby 1.rb 36ms 0.9ms 141.8MB 12ms 30ms truffleruby 24.2.1
ruby 1.rb 51ms 1.3ms 12.8MB 40ms 0ms ruby 3.4.4
ruby 1.rb 54ms 1.3ms 12.9MB 40ms 4ms ruby/yjit 3.4.4

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 2.rb 831ms 18ms 310.8MB 1067ms 110ms truffleruby 24.2.1
perl 2.pl timeout 0.0ms 6.1MB 4990ms 0ms perl 5.40.2
ruby 2.rb timeout 0.0ms 12.8MB 4983ms 0ms 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
ruby 2-m.rb 310ms 3.7ms 323.2MB 563ms 110ms truffleruby 24.2.1
ruby 2.rb 1029ms 3.6ms 13.5MB 1017ms 0ms ruby/yjit 3.4.4
perl 2.pl 2829ms 163ms 6.1MB 2820ms 0ms perl 5.40.2
ruby 2.rb 2937ms 80ms 12.8MB 2920ms 3ms ruby 3.4.4

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
perl 4.pl timeout 0.0ms 9.9MB 19817ms 10ms perl 5.40.2
ruby 4.rb timeout 0.0ms 12.9MB 4983ms 3ms 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 444.0MB 5170ms 240ms truffleruby 24.2.1

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 4.rb 4929ms 35ms 450.6MB 5243ms 210ms truffleruby 24.2.1
perl 4.pl timeout 0.0ms 10.1MB 19537ms 10ms perl 5.40.2
ruby 4.rb timeout 0.0ms 12.9MB 4980ms 3ms ruby 3.4.4
ruby 4.rb timeout 0.0ms 13.5MB 4987ms 0ms ruby/yjit 3.4.4

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 4.rb 1454ms 17ms 382.2MB 1783ms 143ms truffleruby 24.2.1
perl 4-m.pl 3441ms 7.2ms 9.5MB 13347ms 3ms perl 5.40.2
ruby 4.rb timeout 0.0ms 12.9MB 4980ms 3ms ruby 3.4.4
ruby 4.rb timeout 0.0ms 13.6MB 4980ms 0ms ruby/yjit 3.4.4