Perl VS Go benchmarks

Current benchmark data was generated on Sat Nov 16 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 2720ms 34ms 46.1MB 5730ms 43ms go 1.23.3
go 1.go 3817ms 45ms 51.5MB 3800ms 0ms tinygo 0.34.0
perl 1.pl timeout 0.0ms 77.6MB 4940ms 43ms perl 5.40.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 239ms 2.7ms 8.1MB 393ms 13ms go 1.23.3
go 1.go 248ms 36ms 6.5MB 237ms 3ms tinygo 0.34.0
perl 1.pl 1795ms 22ms 14.3MB 1777ms 3ms 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 127ms 1.8ms 5.4MB 400ms 3ms go 1.23.3
perl 1.pl 3614ms 17ms 10.9MB 3603ms 0ms 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.1ms 5.4MB 37ms 0ms go 1.23.3
perl 1.pl 374ms 6.5ms 6.6MB 363ms 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.1ms 0.1MB 0ms 0ms tinygo 0.34.0
go 1.go 1.4ms 0.1ms 3.4MB 0ms 0ms go 1.23.3
perl 1.pl 2.7ms 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 348ms 4.4ms 0.1MB 337ms 0ms tinygo 0.34.0
go 1.go 362ms 2.1ms 3.4MB 350ms 0ms go 1.23.3
perl 2.pl timeout 0.0ms 6.3MB 4990ms 0ms perl 5.40.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 37ms 1.4ms 2.1MB 30ms 0ms tinygo 0.34.0
go 1.go 40ms 0.4ms 3.4MB 30ms 0ms go 1.23.3
perl 2.pl 2722ms 8.2ms 6.1MB 2710ms 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 1890ms 3.1ms 5.5MB 7367ms 0ms go 1.23.3
go 1.go 3654ms 21ms 5.5MB 3643ms 3ms go 1.23.3
go 1.go timeout 0.0ms 2.3MB 4990ms 0ms tinygo 0.34.0
perl 4.pl timeout 0.0ms 14.0MB 19773ms 3ms 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 3.5ms 5.5MB 1820ms 7ms go 1.23.3
go 1.go 922ms 9.4ms 3.4MB 913ms 0ms go 1.23.3
go 1.go 1392ms 2.1ms 0.4MB 1380ms 0ms tinygo 0.34.0
perl 4.pl timeout 0.0ms 14.1MB 19587ms 7ms 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 2.3ms 5.4MB 437ms 3ms go 1.23.3
go 1.go 235ms 4.7ms 3.4MB 227ms 0ms go 1.23.3
go 1.go 350ms 0.2ms 0.3MB 340ms 0ms tinygo 0.34.0
perl 4-m.pl 3421ms 21ms 12.7MB 13180ms 17ms perl 5.40.0