Perl VS Go benchmarks

Current benchmark data was generated on Sun Dec 01 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
go 1-m.go 2710ms 23ms 43.6MB 5730ms 53ms go 1.23.3
go 1.go 3491ms 59ms 52.2MB 3473ms 3ms tinygo 0.34.0
perl 1.pl timeout 0.0ms 77.6MB 4947ms 37ms perl 5.40.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 229ms 5.1ms 5.6MB 213ms 0ms tinygo 0.34.0
go 1-m.go 238ms 2.0ms 8.2MB 400ms 7ms go 1.23.3
perl 1.pl 1789ms 18ms 14.4MB 1767ms 7ms perl 5.40.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 128ms 0.9ms 5.4MB 397ms 3ms go 1.23.3
perl 1.pl 3646ms 17ms 11.0MB 3633ms 3ms perl 5.40.0

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 18ms 0.2ms 5.5MB 37ms 0ms go 1.23.3
perl 1.pl 373ms 5.9ms 6.6MB 360ms 0ms perl 5.40.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 0.7ms 0.3ms 0.1MB 0ms 0ms tinygo 0.34.0
go 1.go 1.5ms 0.1ms 3.4MB 0ms 0ms go 1.23.3
perl 1.pl 2.9ms 0.4ms 5.1MB 0ms 0ms perl 5.40.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 344ms 0.4ms 0.1MB 337ms 0ms tinygo 0.34.0
go 1.go 361ms 1.5ms 3.4MB 347ms 0ms go 1.23.3
perl 2.pl timeout 0.0ms 6.1MB 4983ms 0ms perl 5.40.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 38ms 0.6ms 0.1MB 30ms 0ms tinygo 0.34.0
go 1.go 40ms 1.0ms 3.4MB 30ms 0ms go 1.23.3
perl 2.pl 2764ms 20ms 6.1MB 2753ms 0ms perl 5.40.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 1907ms 17ms 5.4MB 7330ms 10ms go 1.23.3
go 1.go 3680ms 35ms 5.4MB 3673ms 0ms go 1.23.3
go 1.go timeout 0.0ms 0.5MB 4990ms 0ms tinygo 0.34.0
perl 4.pl timeout 0.0ms 14.0MB 19700ms 13ms perl 5.40.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 479ms 0.2ms 5.5MB 1817ms 3ms go 1.23.3
go 1.go 934ms 5.6ms 3.4MB 927ms 0ms go 1.23.3
go 1.go 1390ms 1.4ms 0.4MB 1380ms 0ms tinygo 0.34.0
perl 4.pl timeout 0.0ms 14.3MB 19487ms 13ms perl 5.40.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 126ms 0.7ms 5.4MB 447ms 0ms go 1.23.3
go 1.go 234ms 4.3ms 3.4MB 223ms 0ms go 1.23.3
go 1.go 349ms 0.1ms 0.3MB 340ms 0ms tinygo 0.34.0
perl 4-m.pl 3406ms 10ms 13.7MB 13160ms 7ms perl 5.40.0