Lua VS Go benchmarks

Current benchmark data was generated on Tue Dec 31 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 2534ms 14ms 41.9MB 5390ms 50ms go 1.23.4
go 1.go 2615ms 48ms 52.2MB 2603ms 0ms tinygo 0.35.0
lua 1.lua 3311ms 71ms 172.9MB 3173ms 127ms luajit 2.1.0-beta3
lua 1.lua timeout 0.0ms 104.9MB 4940ms 47ms lua 5.4.7

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 219ms 1.4ms 6.8MB 210ms 0ms tinygo 0.35.0
go 1-m.go 225ms 0.9ms 7.9MB 373ms 13ms go 1.23.4
lua 1.lua 277ms 1.4ms 15.6MB 257ms 3ms luajit 2.1.0-beta3
lua 1.lua 757ms 1.9ms 17.0MB 743ms 0ms lua 5.4.7

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 0.5ms 0.0ms 0.1MB 0ms 0ms tinygo 0.35.0
go 1.go 1.3ms 0.1ms 3.4MB 0ms 0ms go 1.23.4
lua 1.lua 1.5ms 0.0ms 2.4MB 0ms 0ms luajit 2.1.0-beta3
lua 1.lua 2.2ms 1.0ms 2.1MB 0ms 0ms lua 5.4.7

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 1523ms 5.6ms 36.8MB 3107ms 37ms go 1.23.4
go 2-m.go 1741ms 13ms 43.1MB 3667ms 37ms go 1.23.4
go 1.go 1890ms 41ms 52.1MB 1877ms 0ms tinygo 0.35.0
go 2.go 2426ms 14ms 120.4MB 2400ms 10ms tinygo 0.35.0
lua 1.lua timeout 0.0ms 107.3MB 4950ms 37ms lua 5.4.7
lua 1.lua timeout 0.0ms 149.3MB 4937ms 47ms luajit 2.1.0-beta3

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 349ms 4.9ms 14.1MB 667ms 23ms go 1.23.4
go 1.go 358ms 5.5ms 13.6MB 347ms 0ms tinygo 0.35.0
go 2-m.go 388ms 1.9ms 14.2MB 777ms 27ms go 1.23.4
go 2.go 523ms 7.2ms 22.8MB 510ms 0ms tinygo 0.35.0
lua 1.lua 1019ms 0.9ms 31.1MB 983ms 20ms luajit 2.1.0-beta3
lua 1.lua 2026ms 40ms 28.6MB 2003ms 3ms lua 5.4.7

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 331ms 6.3ms 0.1MB 323ms 0ms tinygo 0.35.0
go 1.go 344ms 2.0ms 3.4MB 337ms 0ms go 1.23.4
lua 4.lua 677ms 3.8ms 2.3MB 670ms 0ms luajit 2.1.0-beta3
lua 4.lua timeout 0.0ms 2.3MB 4987ms 0ms lua 5.4.7

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 34ms 0.8ms 0.1MB 20ms 0ms tinygo 0.35.0
go 1.go 38ms 0.5ms 3.4MB 30ms 0ms go 1.23.4
lua 4.lua 72ms 3.0ms 2.3MB 60ms 0ms luajit 2.1.0-beta3
lua 4.lua 1042ms 22ms 2.3MB 1033ms 0ms lua 5.4.7

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 1818ms 34ms 5.4MB 6960ms 13ms go 1.23.4
go 1.go 3496ms 38ms 5.5MB 3487ms 0ms go 1.23.4
lua 1.lua 3844ms 19ms 2.5MB 3830ms 0ms luajit 2.1.0-beta3
go 1.go timeout 0.0ms 0.5MB 4990ms 0ms tinygo 0.35.0
lua 1.lua timeout 0.0ms 2.4MB 4990ms 0ms lua 5.4.7

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 453ms 6.4ms 5.4MB 1723ms 0ms go 1.23.4
go 1.go 887ms 4.1ms 3.4MB 873ms 0ms go 1.23.4
lua 1.lua 970ms 12ms 2.4MB 960ms 0ms luajit 2.1.0-beta3
go 1.go 1335ms 3.6ms 2.1MB 1323ms 0ms tinygo 0.35.0
lua 1.lua timeout 0.0ms 2.1MB 4990ms 0ms lua 5.4.7

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 117ms 0.9ms 5.4MB 417ms 0ms go 1.23.4
go 1.go 224ms 4.2ms 3.4MB 217ms 0ms go 1.23.4
lua 1.lua 243ms 1.7ms 2.3MB 230ms 0ms luajit 2.1.0-beta3
go 1.go 333ms 7.4ms 0.3MB 323ms 0ms tinygo 0.35.0
lua 1.lua timeout 0.0ms 2.0MB 4990ms 0ms lua 5.4.7