Perl VS Ruby benchmarks

Current benchmark data was generated on Sun Jun 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
ruby 1-m.rb 4549ms 73ms 838.0MB 6403ms 490ms truffleruby 24.2.1
ruby 1.rb 4697ms 113ms 110.0MB 4607ms 77ms ruby/yjit 3.4.4
perl 1.pl timeout 0.0ms 77.8MB 4960ms 27ms perl 5.40.2
ruby 1.rb timeout 0.0ms 70.4MB 4953ms 37ms ruby 3.4.4

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 1.rb 489ms 7.3ms 20.3MB 463ms 10ms ruby/yjit 3.4.4
ruby 1-m.rb 502ms 12ms 405.6MB 983ms 153ms truffleruby 24.2.1
ruby 1.rb 948ms 7.8ms 19.5MB 927ms 10ms ruby 3.4.4
perl 1.pl 1815ms 12ms 14.4MB 1800ms 0ms perl 5.40.2

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 6.rb 2020ms 7.1ms 23.0MB 1993ms 13ms ruby/yjit 3.4.4
ruby 6-m.rb 2228ms 213ms 408.8MB 5793ms 337ms truffleruby 24.2.1
perl 1.pl 3556ms 18ms 10.9MB 3543ms 0ms perl 5.40.2
ruby 6.rb 3691ms 14ms 22.4MB 3667ms 10ms ruby 3.4.4

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 6.rb 255ms 2.3ms 15.2MB 240ms 0ms ruby/yjit 3.4.4
perl 1.pl 367ms 3.7ms 6.6MB 357ms 0ms perl 5.40.2
ruby 6.rb 420ms 5.4ms 14.5MB 403ms 0ms ruby 3.4.4
ruby 6-m.rb 729ms 109ms 365.6MB 1803ms 163ms 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.3ms 5.3MB 0ms 0ms perl 5.40.2
ruby 1.rb 34ms 0.5ms 141.5MB 10ms 26ms truffleruby 24.2.1
ruby 1.rb 50ms 1.4ms 12.9MB 38ms 2ms ruby/yjit 3.4.4
ruby 1.rb 51ms 1.7ms 12.8MB 36ms 2ms ruby 3.4.4

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 2.rb 823ms 8.8ms 310.2MB 1070ms 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 3ms ruby 3.4.4
ruby 2.rb timeout 0.0ms 13.5MB 4983ms 3ms 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 323ms 5.2ms 325.5MB 593ms 110ms truffleruby 24.2.1
ruby 2.rb 1025ms 6.4ms 13.5MB 1010ms 3ms ruby/yjit 3.4.4
perl 2.pl 2719ms 106ms 6.1MB 2707ms 0ms perl 5.40.2
ruby 2.rb 2919ms 94ms 12.8MB 2903ms 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 19830ms 0ms 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 4980ms 3ms ruby/yjit 3.4.4
ruby 4.rb timeout 0.0ms 436.2MB 5167ms 233ms truffleruby 24.2.1

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 4.rb 4820ms 15ms 423.5MB 5103ms 203ms truffleruby 24.2.1
perl 4.pl timeout 0.0ms 10.0MB 19553ms 10ms perl 5.40.2
ruby 4.rb timeout 0.0ms 12.9MB 4987ms 3ms ruby 3.4.4
ruby 4.rb timeout 0.0ms 13.5MB 4980ms 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 1453ms 19ms 405.2MB 1797ms 150ms truffleruby 24.2.1
perl 4-m.pl 3429ms 2.4ms 9.5MB 13317ms 7ms perl 5.40.2
ruby 4.rb timeout 0.0ms 12.9MB 4983ms 7ms ruby 3.4.4
ruby 4.rb timeout 0.0ms 13.6MB 4980ms 7ms ruby/yjit 3.4.4