Perl VS Ruby benchmarks

Current benchmark data was generated on Sun Jul 13 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 4770ms 133ms 110.1MB 4677ms 77ms ruby/yjit 3.4.4
perl 1.pl timeout 0.0ms 77.8MB 4963ms 23ms perl 5.40.2
ruby 1.rb timeout 0.0ms 70.5MB 4950ms 33ms ruby 3.4.4
ruby 1.rb timeout 0.0ms 796.7MB 6620ms 720ms truffleruby 24.2.1

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 1.rb 498ms 0.9ms 20.3MB 473ms 10ms ruby/yjit 3.4.4
ruby 1-m.rb 503ms 8.2ms 407.1MB 980ms 150ms truffleruby 24.2.1
ruby 1.rb 947ms 3.2ms 19.5MB 923ms 13ms ruby 3.4.4
perl 1.pl 1814ms 11ms 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 2046ms 3.0ms 23.0MB 2023ms 10ms ruby/yjit 3.4.4
ruby 6-m.rb 2107ms 209ms 406.5MB 5403ms 323ms truffleruby 24.2.1
ruby 6.rb 3692ms 15ms 22.4MB 3673ms 10ms ruby 3.4.4
perl 1.pl 3699ms 175ms 10.9MB 3687ms 0ms perl 5.40.2

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 6.rb 259ms 4.3ms 15.2MB 237ms 10ms ruby/yjit 3.4.4
perl 1.pl 365ms 1.2ms 6.6MB 357ms 0ms perl 5.40.2
ruby 6.rb 415ms 1.8ms 14.4MB 397ms 3ms ruby 3.4.4
ruby 6-m.rb 843ms 29ms 380.9MB 2103ms 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.7ms 0.4ms 5.3MB 0ms 0ms perl 5.40.2
ruby 1.rb 34ms 0.4ms 141.1MB 12ms 24ms truffleruby 24.2.1
ruby 1.rb 51ms 1.1ms 12.8MB 38ms 0ms ruby 3.4.4
ruby 1.rb 53ms 0.4ms 12.9MB 38ms 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 836ms 14ms 325.0MB 1103ms 117ms 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 4977ms 10ms 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 309ms 6.6ms 309.6MB 560ms 103ms truffleruby 24.2.1
ruby 2.rb 1028ms 6.1ms 13.5MB 1010ms 3ms ruby/yjit 3.4.4
perl 2.pl 2731ms 3.5ms 6.1MB 2723ms 0ms perl 5.40.2
ruby 2.rb 2980ms 14ms 12.8MB 2963ms 7ms 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 10.0MB 19643ms 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.5MB 4980ms 0ms ruby/yjit 3.4.4
ruby 4.rb timeout 0.0ms 436.6MB 5167ms 240ms truffleruby 24.2.1

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
ruby 4.rb 4848ms 12ms 433.6MB 5140ms 203ms truffleruby 24.2.1
perl 4.pl timeout 0.0ms 10.0MB 19530ms 3ms perl 5.40.2
ruby 4.rb timeout 0.0ms 12.8MB 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
ruby 4.rb 1458ms 6.2ms 377.4MB 1793ms 157ms truffleruby 24.2.1
perl 4-m.pl 3449ms 32ms 9.4MB 13333ms 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 3ms ruby/yjit 3.4.4