Nim VS Go benchmarks

Current benchmark data was generated on Thu Feb 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
nim 2.nim 835ms 5.3ms 34.4MB 813ms 7ms nim 2.0.2
nim 2.nim 1170ms 1.0ms 34.7MB 1150ms 7ms nim/clang 2.0.2
go 1-m.go 2665ms 13ms 44.2MB 5553ms 47ms go 1.21.6
go 1.go 4172ms 25ms 51.6MB 4157ms 3ms tinygo 0.30.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 80ms 2.9ms 5.5MB 70ms 0ms nim 2.0.2
nim 2.nim 113ms 2.9ms 5.8MB 100ms 0ms nim/clang 2.0.2
go 1-m.go 237ms 1.8ms 7.8MB 393ms 3ms go 1.21.6
go 1.go 316ms 4.0ms 6.6MB 307ms 0ms tinygo 0.30.0

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 464ms 54ms 15.4MB 1767ms 0ms go 1.21.6
go 1.go 2438ms 2.9ms 256.6MB 2400ms 23ms tinygo 0.30.0
nim 1.nim timeout 0.0ms 549.4MB 2490ms 2053ms nim 2.0.2
nim 1.nim timeout 0.0ms 558.6MB 2537ms 1997ms nim/clang 2.0.2

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 39ms 4.8ms 7.2MB 127ms 0ms go 1.21.6
go 1.go 387ms 1.7ms 65.8MB 373ms 0ms tinygo 0.30.0
nim 1.nim 4326ms 9.0ms 519.8MB 2247ms 1653ms nim/clang 2.0.2
nim 1.nim 4400ms 29ms 519.4MB 2180ms 1793ms nim 2.0.2

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 123ms 0.2ms 5.3MB 370ms 0ms go 1.21.6
nim 2.nim 188ms 3.5ms 1.5MB 177ms 0ms nim 2.0.2
nim 2.nim 239ms 3.2ms 1.8MB 227ms 0ms nim/clang 2.0.2
nim 1.nim 549ms 1.1ms 1.8MB 447ms 87ms nim/clang 2.0.2
nim 1.nim 573ms 0.7ms 1.5MB 463ms 90ms nim 2.0.2

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 17ms 0.4ms 5.3MB 30ms 0ms go 1.21.6
nim 2.nim 20ms 0.4ms 1.5MB 10ms 0ms nim 2.0.2
nim 2.nim 26ms 0.6ms 1.6MB 20ms 0ms nim/clang 2.0.2
nim 1.nim 58ms 0.6ms 1.8MB 43ms 0ms nim/clang 2.0.2
nim 1.nim 61ms 1.0ms 1.5MB 43ms 7ms nim 2.0.2

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 0.6ms 0.1ms 0.1MB 0ms 0ms tinygo 0.30.0
nim 1.nim 1.0ms 0.1ms 1.6MB 0ms 0ms nim 2.0.2
nim 1.nim 1.2ms 0.1ms 1.9MB 0ms 0ms nim/clang 2.0.2
go 1.go 1.5ms 0.1ms 3.1MB 0ms 0ms go 1.21.6

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-http2.go 121ms 6.0ms 59.4MB 300ms 103ms go 1.21.6
go 2-m.go 445ms 7.9ms 175.9MB 593ms 670ms go 1.21.6
go 1-m.go 454ms 8.3ms 167.7MB 667ms 603ms go 1.21.6
nim 1.nim 895ms 13ms 97.3MB 283ms 583ms nim 2.0.2
nim 1.nim 909ms 5.9ms 98.3MB 293ms 583ms nim/clang 2.0.2

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-http2.go 25ms 14ms 25.4MB 50ms 30ms go 1.21.6
go 2-m.go 111ms 29ms 33.9MB 87ms 83ms go 1.21.6
go 1-m.go 112ms 8.6ms 38.1MB 97ms 97ms go 1.21.6
nim 1.nim 147ms 2.3ms 18.0MB 27ms 100ms nim 2.0.2
nim 1.nim 149ms 1.0ms 18.1MB 43ms 90ms nim/clang 2.0.2

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 108ms 1.5ms 1.6MB 100ms 0ms nim/clang 2.0.2
nim 2.nim 109ms 2.7ms 1.4MB 97ms 0ms nim 2.0.2
go 3.go 128ms 1.8ms 3.3MB 120ms 0ms go 1.21.6
go 3.go 135ms 4.0ms 0.3MB 127ms 0ms tinygo 0.30.0
nim 1.nim timeout 0.0ms 1.3MB 4990ms 0ms nim 2.0.2
nim 1.nim timeout 0.0ms 1.5MB 4990ms 0ms nim/clang 2.0.2

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 316ms 0.4ms 1.9MB 307ms 0ms nim/clang 2.0.2
nim 2.nim 323ms 4.4ms 1.4MB 313ms 0ms nim 2.0.2
go 3.go 371ms 1.4ms 3.3MB 360ms 0ms go 1.21.6
go 3.go 388ms 1.8ms 2.3MB 380ms 0ms tinygo 0.30.0
nim 1.nim timeout 0.0ms 1.3MB 4990ms 0ms nim 2.0.2
nim 1.nim timeout 0.0ms 1.5MB 4990ms 0ms nim/clang 2.0.2

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 48ms 0.6ms 1.5MB 40ms 0ms nim/clang 2.0.2
nim 2.nim 49ms 0.7ms 1.3MB 40ms 0ms nim 2.0.2
go 3.go 63ms 0.8ms 3.1MB 53ms 0ms go 1.21.6
go 3.go 71ms 5.8ms 0.1MB 63ms 0ms tinygo 0.30.0
nim 1.nim 536ms 10ms 1.5MB 523ms 0ms nim/clang 2.0.2
nim 1.nim 536ms 8.6ms 1.3MB 523ms 0ms nim 2.0.2

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 389ms 2.4ms 4.8MB 377ms 0ms nim/clang 2.0.2
nim 1.nim 577ms 3.8ms 4.5MB 563ms 0ms nim 2.0.2
go 1.go 3215ms 5.5ms 7.3MB 3203ms 3ms go 1.21.6
go 1.go 4022ms 4.0ms 5.8MB 4013ms 0ms tinygo 0.30.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 19ms 0.8ms 1.9MB 10ms 0ms nim/clang 2.0.2
nim 1.nim 28ms 0.5ms 1.6MB 20ms 0ms nim 2.0.2
go 1.go 138ms 2.8ms 3.3MB 127ms 0ms go 1.21.6
go 1.go 168ms 2.2ms 0.3MB 160ms 0ms tinygo 0.30.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 553ms 0.7ms 34.4MB 533ms 3ms nim 2.0.2
nim 1.nim 653ms 8.9ms 36.5MB 633ms 3ms nim/clang 2.0.2
go 1-m.go 1632ms 20ms 39.1MB 3303ms 47ms go 1.21.6
go 2-m.go 1860ms 6.1ms 41.4MB 3863ms 37ms go 1.21.6
go 1.go 2314ms 36ms 51.7MB 2297ms 7ms tinygo 0.30.0
go 2.go 3797ms 21ms 119.4MB 3773ms 7ms tinygo 0.30.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 122ms 0.7ms 9.8MB 110ms 0ms nim 2.0.2
nim 1.nim 143ms 2.1ms 10.0MB 130ms 0ms nim/clang 2.0.2
go 1-m.go 365ms 1.8ms 13.8MB 710ms 13ms go 1.21.6
go 2-m.go 409ms 1.0ms 13.8MB 820ms 20ms go 1.21.6
go 1.go 445ms 1.4ms 13.8MB 433ms 0ms tinygo 0.30.0
go 2.go 684ms 10ms 39.5MB 670ms 0ms tinygo 0.30.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 318ms 1.0ms 1.8MB 310ms 0ms nim 2.0.2
nim 2.nim 343ms 3.5ms 2.0MB 333ms 0ms nim/clang 2.0.2
go 1.go 348ms 1.1ms 2.1MB 340ms 0ms tinygo 0.30.0
go 1.go 364ms 0.9ms 3.3MB 350ms 0ms go 1.21.6

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 34ms 0.5ms 1.8MB 23ms 0ms nim 2.0.2
go 1.go 36ms 0.1ms 0.1MB 30ms 0ms tinygo 0.30.0
nim 2.nim 36ms 0.1ms 2.0MB 30ms 0ms nim/clang 2.0.2
go 1.go 39ms 0.2ms 3.3MB 30ms 0ms go 1.21.6

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 282ms 2.6ms 41.5MB 270ms 0ms nim 2.0.2
go 1.go 311ms 4.6ms 72.5MB 297ms 0ms go 1.21.6
go 1.go 331ms 2.1ms 42.8MB 320ms 0ms tinygo 0.30.0
nim 1.nim 351ms 9.9ms 41.8MB 337ms 0ms nim/clang 2.0.2
go 2.go 437ms 5.1ms 17.8MB 427ms 0ms tinygo 0.30.0
go 2.go 740ms 3.8ms 21.7MB 723ms 3ms go 1.21.6

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 56ms 1.3ms 11.5MB 47ms 0ms nim 2.0.2
go 1.go 62ms 1.2ms 21.6MB 47ms 0ms go 1.21.6
nim 1.nim 65ms 1.0ms 11.8MB 53ms 0ms nim/clang 2.0.2
go 1.go 66ms 1.0ms 12.6MB 53ms 0ms tinygo 0.30.0
go 2.go 110ms 2.0ms 4.6MB 100ms 0ms tinygo 0.30.0
go 2.go 181ms 1.7ms 7.2MB 170ms 0ms go 1.21.6

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 1623ms 6.2ms 152.4MB 1583ms 23ms nim/clang 2.0.2
nim 1.nim 1647ms 11ms 151.5MB 1617ms 13ms nim 2.0.2
go 3.go timeout 0.0ms 128.0MB 4977ms 47ms go 1.21.6
go 3.go timeout 0.0ms 106.6MB 4980ms 7ms tinygo 0.30.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 172ms 1.3ms 16.4MB 153ms 7ms nim 2.0.2
nim 1.nim 173ms 1.6ms 16.7MB 160ms 0ms nim/clang 2.0.2
go 3.go 1859ms 155ms 20.2MB 1833ms 33ms go 1.21.6
go 3.go 2681ms 113ms 30.4MB 2667ms 0ms tinygo 0.30.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 1911ms 7.7ms 5.3MB 7327ms 0ms go 1.21.6
nim 1.nim 3574ms 1.9ms 1.6MB 3567ms 0ms nim/clang 2.0.2
nim 1.nim 3591ms 12ms 1.4MB 3580ms 0ms nim 2.0.2
go 1.go 3639ms 25ms 5.4MB 3630ms 0ms go 1.21.6
go 1.go timeout 0.0ms 2.4MB 4990ms 0ms tinygo 0.30.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 479ms 0.9ms 5.3MB 1817ms 3ms go 1.21.6
nim 1.nim 895ms 0.8ms 1.5MB 887ms 0ms nim/clang 2.0.2
nim 1.nim 899ms 2.9ms 1.8MB 890ms 0ms nim 2.0.2
go 1.go 928ms 8.2ms 3.3MB 923ms 0ms go 1.21.6
go 1.go 1394ms 5.3ms 0.4MB 1383ms 0ms tinygo 0.30.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 126ms 1.3ms 5.3MB 437ms 0ms go 1.21.6
nim 1.nim 226ms 0.0ms 1.5MB 217ms 0ms nim/clang 2.0.2
nim 1.nim 227ms 1.0ms 1.8MB 220ms 0ms nim 2.0.2
go 1.go 236ms 5.1ms 3.3MB 223ms 0ms go 1.21.6
go 1.go 349ms 0.4ms 0.3MB 340ms 0ms tinygo 0.30.0