Go VS Python 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
python 1.py 1164ms 8.8ms 95.7MB 1100ms 47ms pypy 3.10.14
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
python 1.py timeout 0.0ms 40.9MB 4970ms 13ms cpython 3.13.0
python 1.py timeout 0.0ms 40.5MB 4767ms 213ms pyston 3.8.12

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
python 1.py 93ms 0.7ms 67.9MB 60ms 17ms pypy 3.10.14
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
python 1.py 474ms 4.5ms 11.9MB 450ms 7ms pyston 3.8.12
python 1.py 716ms 13ms 12.8MB 707ms 0ms cpython 3.13.0

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 521ms 93ms 15.6MB 1973ms 3ms go 1.23.3
python 1.py 1187ms 11ms 103.5MB 1140ms 30ms pypy 3.10.14
go 1.go 1415ms 5.8ms 256.7MB 1377ms 23ms tinygo 0.34.0
python 1.py timeout 0.0ms 21.3MB 4977ms 10ms cpython 3.13.0
python 1.py timeout 0.0ms 17.4MB 4980ms 3ms pyston 3.8.12

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 50ms 18ms 7.5MB 163ms 0ms go 1.23.3
python 1.py 221ms 6.2ms 84.3MB 170ms 33ms pypy 3.10.14
go 1.go 256ms 1.1ms 66.7MB 240ms 0ms tinygo 0.34.0
python 1.py 582ms 3.3ms 20.4MB 557ms 7ms cpython 3.13.0
python 1.py 645ms 2.4ms 16.8MB 623ms 3ms pyston 3.8.12

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 120ms 0.7ms 10.2MB 110ms 3ms go 1.23.3
python 1.py 251ms 2.6ms 82.9MB 217ms 17ms pypy 3.10.14
python 1.py 358ms 6.5ms 12.6MB 343ms 0ms cpython 3.13.0
python 1.py 1992ms 1.4ms 9.6MB 1977ms 0ms pyston 3.8.12

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 36ms 0.8ms 8.2MB 30ms 0ms go 1.23.3
python 1.py 99ms 3.0ms 62.9MB 73ms 17ms pypy 3.10.14
python 1.py 109ms 4.3ms 11.9MB 97ms 0ms cpython 3.13.0
python 1.py 345ms 0.2ms 8.8MB 330ms 0ms pyston 3.8.12

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 722ms 0.7ms 5.6MB 2777ms 0ms go 1.23.3
go 3.go 2276ms 4.9ms 50.2MB 2260ms 0ms tinygo 0.34.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 75ms 0.2ms 5.5MB 207ms 0ms go 1.23.3
go 3.go 488ms 2.3ms 50.1MB 473ms 0ms tinygo 0.34.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
python 1.py 1908ms 7.1ms 88.3MB 1867ms 23ms pypy 3.10.14
python 5-m.py 2493ms 42ms 12.5MB 3617ms 1003ms pyston 3.8.12
python 5-m.py 2816ms 14ms 64.9MB 3960ms 837ms pypy 3.10.14
python 1.py 3005ms 19ms 8.1MB 2993ms 0ms pyston 3.8.12
python 5-m.py 3408ms 32ms 13.8MB 4537ms 1013ms cpython 3.13.0
python 1.py 4612ms 106ms 8.8MB 4597ms 0ms cpython 3.13.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
python 1.py 253ms 2.4ms 63.6MB 230ms 10ms pypy 3.10.14
python 1.py 314ms 3.5ms 8.1MB 303ms 0ms pyston 3.8.12
python 5-m.py 317ms 4.6ms 12.4MB 413ms 143ms pyston 3.8.12
python 5-m.py 406ms 4.6ms 13.9MB 493ms 137ms cpython 3.13.0
python 1.py 472ms 7.6ms 8.8MB 457ms 0ms cpython 3.13.0
python 5-m.py 544ms 10ms 64.9MB 807ms 310ms pypy 3.10.14

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
python 1.py 11ms 0.9ms 7.6MB 10ms 0ms pyston 3.8.12
python 1.py 14ms 1.1ms 8.5MB 0ms 0ms cpython 3.13.0
python 1.py 29ms 1.0ms 51.0MB 10ms 10ms pypy 3.10.14

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-http2.go 109ms 2.4ms 57.5MB 300ms 73ms go 1.23.3
go 1-m.go 478ms 56ms 174.5MB 643ms 653ms go 1.23.3
go 2-m.go 485ms 29ms 172.5MB 660ms 647ms go 1.23.3
python 1.py 2272ms 127ms 33.5MB 1563ms 1653ms cpython 3.13.0
python 1.py 2302ms 178ms 36.3MB 1130ms 1547ms pyston 3.8.12
python 1.py 4585ms 82ms 106.7MB 2800ms 1187ms pypy 3.10.14

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-http2.go 22ms 12ms 22.7MB 45ms 25ms go 1.23.3
go 2-m.go 98ms 17ms 40.5MB 73ms 113ms go 1.23.3
go 1-m.go 128ms 4.8ms 38.2MB 83ms 137ms go 1.23.3
python 1.py 1088ms 1.2ms 30.7MB 223ms 283ms pyston 3.8.12
python 1.py 1199ms 99ms 28.6MB 293ms 300ms cpython 3.13.0
python 1.py 1518ms 319ms 88.3MB 687ms 227ms pypy 3.10.14

json-serde

Input: sample 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 2-ffi.go 45ms 0.9ms 40.6MB 40ms 0ms go 1.23.3
go 1.go 142ms 3.4ms 18.4MB 127ms 3ms go 1.23.3
python 1.py 198ms 3.4ms 38.6MB 170ms 13ms pyston 3.8.12
python 1.py 221ms 1.9ms 38.5MB 203ms 7ms cpython 3.13.0
python 1.py 290ms 3.3ms 87.3MB 250ms 23ms pypy 3.10.14

Input: canada 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 2-ffi.go 238ms 5.4ms 149.3MB 240ms 20ms go 1.23.3
go 1.go 775ms 3.8ms 104.7MB 763ms 10ms go 1.23.3
python 1.py 1827ms 9.2ms 220.5MB 1667ms 143ms pyston 3.8.12
python 1.py 1913ms 11ms 221.8MB 1837ms 60ms pypy 3.10.14
python 1.py 1923ms 6.6ms 222.5MB 1820ms 87ms cpython 3.13.0

knucleotide

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 7-m.go 789ms 4.1ms 41.6MB 2813ms 27ms go 1.23.3
python 3-m.py 2372ms 54ms 138.0MB 8053ms 343ms pypy 3.10.14
python 3-m.py 3126ms 19ms 34.1MB 11777ms 140ms pyston 3.8.12
python 3.py timeout 0.0ms 35.2MB 90ms 17ms cpython 3.13.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 7-m.go 143ms 5.6ms 29.1MB 367ms 37ms go 1.23.3
python 3-m.py 375ms 2.2ms 77.1MB 933ms 163ms pypy 3.10.14
python 3-m.py 394ms 2.3ms 17.6MB 1267ms 93ms pyston 3.8.12
python 3-m.py 672ms 6.9ms 17.2MB 2367ms 60ms cpython 3.13.0

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 131ms 3.4ms 3.4MB 123ms 0ms go 1.23.3
go 3.go 133ms 2.8ms 0.3MB 123ms 0ms tinygo 0.34.0
python 2.py 145ms 2.6ms 58.0MB 117ms 10ms pypy 3.10.14
python 1.py 182ms 3.8ms 59.6MB 143ms 23ms pypy 3.10.14
python 1.py 718ms 9.3ms 8.9MB 707ms 0ms pyston 3.8.12
python 2.py 835ms 13ms 8.5MB 817ms 0ms pyston 3.8.12
python 1.py 1128ms 15ms 9.4MB 1110ms 0ms cpython 3.13.0
python 2.py 1311ms 25ms 9.1MB 1300ms 0ms cpython 3.13.0

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
python 2.py 341ms 8.9ms 58.9MB 317ms 10ms pypy 3.10.14
python 1.py 373ms 0.1ms 60.4MB 357ms 0ms pypy 3.10.14
go 3.go 385ms 6.1ms 3.4MB 377ms 0ms go 1.23.3
go 3.go 391ms 4.4ms 2.1MB 380ms 0ms tinygo 0.34.0
python 1.py 2137ms 24ms 8.9MB 2123ms 0ms pyston 3.8.12
python 2.py 2471ms 28ms 8.5MB 2453ms 3ms pyston 3.8.12
python 1.py 3296ms 12ms 9.4MB 3280ms 0ms cpython 3.13.0
python 2.py 3856ms 36ms 9.1MB 3843ms 0ms cpython 3.13.0

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 65ms 0.5ms 0.1MB 53ms 0ms tinygo 0.34.0
go 3.go 69ms 1.3ms 5.5MB 60ms 0ms go 1.23.3
python 2.py 104ms 1.1ms 57.8MB 77ms 10ms pypy 3.10.14
python 1.py 121ms 3.3ms 58.5MB 93ms 13ms pypy 3.10.14
python 1.py 346ms 5.2ms 8.5MB 333ms 0ms pyston 3.8.12
python 2.py 390ms 6.1ms 8.1MB 377ms 0ms pyston 3.8.12
python 1.py 539ms 9.9ms 9.1MB 523ms 0ms cpython 3.13.0
python 2.py 635ms 25ms 8.8MB 623ms 0ms cpython 3.13.0

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 2682ms 19ms 7.5MB 2673ms 0ms go 1.23.3
go 1.go 4001ms 11ms 5.6MB 3990ms 0ms tinygo 0.34.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 115ms 3.4ms 3.4MB 103ms 0ms go 1.23.3
go 1.go 171ms 2.4ms 2.2MB 160ms 0ms tinygo 0.34.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 1612ms 18ms 36.6MB 3263ms 33ms go 1.23.3
go 2-m.go 1871ms 71ms 43.0MB 3923ms 27ms go 1.23.3
go 1.go 2050ms 9.5ms 52.0MB 2030ms 3ms tinygo 0.34.0
python 1.py 2242ms 21ms 210.2MB 2127ms 100ms pypy 3.10.14
go 2.go 3360ms 7.7ms 90.6MB 3333ms 10ms tinygo 0.34.0
python 1.py timeout 0.0ms 93.9MB 4953ms 27ms cpython 3.13.0
python 1.py timeout 0.0ms 130.4MB 4943ms 40ms pyston 3.8.12

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 365ms 1.7ms 12.1MB 700ms 27ms go 1.23.3
python 1.py 386ms 1.5ms 103.6MB 317ms 50ms pypy 3.10.14
go 2-m.go 410ms 1.5ms 13.9MB 847ms 13ms go 1.23.3
go 1.go 441ms 5.4ms 13.7MB 430ms 0ms tinygo 0.34.0
go 2.go 669ms 4.4ms 29.0MB 657ms 0ms tinygo 0.34.0
python 1.py 2958ms 51ms 37.1MB 2937ms 7ms cpython 3.13.0
python 1.py timeout 0.0ms 48.9MB 4943ms 40ms pyston 3.8.12

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
python 2.py 1351ms 7.9ms 59.8MB 1323ms 17ms pypy 3.10.14
python 1.py 2634ms 23ms 56.6MB 2610ms 10ms pypy 3.10.14
python 1.py timeout 0.0ms 8.8MB 4987ms 3ms cpython 3.13.0
python 2.py timeout 0.0ms 8.8MB 4990ms 0ms cpython 3.13.0
python 1.py timeout 0.0ms 8.3MB 4987ms 3ms pyston 3.8.12
python 2.py timeout 0.0ms 8.1MB 4987ms 0ms pyston 3.8.12

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
python 2.py 176ms 1.4ms 57.6MB 147ms 13ms pypy 3.10.14
python 1.py 301ms 4.2ms 56.6MB 273ms 10ms pypy 3.10.14
python 1.py 926ms 8.6ms 8.3MB 910ms 0ms pyston 3.8.12
python 2.py 1297ms 12ms 8.1MB 1280ms 0ms pyston 3.8.12
python 1.py 3025ms 45ms 8.8MB 3007ms 3ms cpython 3.13.0
python 2.py 3179ms 124ms 8.8MB 3167ms 0ms cpython 3.13.0

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 302ms 4.7ms 71.7MB 287ms 3ms go 1.23.3
go 1.go 361ms 8.8ms 42.8MB 347ms 0ms tinygo 0.34.0
go 2.go 434ms 4.2ms 17.3MB 423ms 0ms tinygo 0.34.0
go 2.go 779ms 0.5ms 21.8MB 763ms 7ms go 1.23.3
python 1.py 2508ms 22ms 369.0MB 2427ms 63ms pypy 3.10.14
python 2.py 2995ms 49ms 632.9MB 2827ms 153ms pyston 3.8.12
python 1.py 4841ms 38ms 320.4MB 4780ms 47ms pyston 3.8.12
python 1.py timeout 0.0ms 321.3MB 4953ms 27ms cpython 3.13.0
python 2.py timeout 0.0ms 633.6MB 4820ms 160ms cpython 3.13.0
python 2.py timeout 0.0ms 959.3MB 4683ms 300ms pypy 3.10.14

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 60ms 0.6ms 21.6MB 47ms 0ms go 1.23.3
go 1.go 65ms 2.5ms 13.7MB 53ms 0ms tinygo 0.34.0
go 2.go 107ms 1.7ms 5.6MB 97ms 0ms tinygo 0.34.0
go 2.go 197ms 2.3ms 7.6MB 180ms 3ms go 1.23.3
python 1.py 539ms 11ms 134.6MB 497ms 27ms pypy 3.10.14
python 2.py 720ms 4.3ms 164.2MB 673ms 30ms pyston 3.8.12
python 1.py 1102ms 6.4ms 86.0MB 1077ms 10ms pyston 3.8.12
python 2.py 1394ms 3.2ms 164.9MB 1350ms 27ms cpython 3.13.0
python 2.py 1533ms 15ms 289.7MB 1447ms 70ms pypy 3.10.14
python 1.py 2681ms 12ms 86.9MB 2650ms 10ms cpython 3.13.0

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 8.go 1125ms 7.4ms 8.4MB 1110ms 3ms go 1.23.3
python 4.py 1902ms 3.9ms 9.0MB 1867ms 20ms pyston 3.8.12
python 4.py 1960ms 11ms 9.4MB 1907ms 37ms cpython 3.13.0
python 4.py 2130ms 10ms 89.1MB 2090ms 23ms pypy 3.10.14

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 8.go 270ms 2.8ms 8.4MB 253ms 3ms go 1.23.3
python 4.py 451ms 6.4ms 8.6MB 440ms 0ms pyston 3.8.12
python 4.py 464ms 1.8ms 9.1MB 450ms 0ms cpython 3.13.0
python 4.py 546ms 9.4ms 83.5MB 503ms 30ms pypy 3.10.14

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
python 1.py 2231ms 14ms 242.0MB 2173ms 37ms pypy 3.10.14
python 1.py 4720ms 6.1ms 226.3MB 4543ms 163ms pyston 3.8.12
go 3.go timeout 0.0ms 122.2MB 4973ms 57ms go 1.23.3
go 3.go timeout 0.0ms 106.4MB 4977ms 10ms tinygo 0.34.0
python 1.py timeout 0.0ms 173.3MB 4927ms 57ms cpython 3.13.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
python 1.py 326ms 2.1ms 84.5MB 293ms 17ms pypy 3.10.14
python 1.py 495ms 2.7ms 30.3MB 460ms 20ms pyston 3.8.12
python 1.py 594ms 3.3ms 29.0MB 567ms 10ms cpython 3.13.0
go 3.go 1796ms 32ms 20.2MB 1780ms 23ms go 1.23.3
go 3.go 2422ms 21ms 30.3MB 2407ms 0ms tinygo 0.34.0

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 0-ffi.go 141ms 0.6ms 11.5MB 133ms 0ms go 1.23.3
python 1.py 3156ms 16ms 8.3MB 3137ms 0ms pyston 3.8.12
python 1.py 3719ms 8.3ms 74.6MB 3673ms 30ms pypy 3.10.14
python 1.py 3812ms 7.4ms 8.8MB 3797ms 0ms cpython 3.13.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 0-ffi.go 46ms 0.7ms 11.9MB 40ms 0ms go 1.23.3
python 1.py 803ms 8.8ms 8.4MB 790ms 0ms pyston 3.8.12
python 1.py 968ms 11ms 8.8MB 953ms 0ms cpython 3.13.0
python 1.py 1035ms 6.9ms 67.5MB 1010ms 7ms pypy 3.10.14

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
python 8.py timeout 0.0ms 16.8MB 43ms 10ms cpython 3.13.0
python 8.py timeout 0.0ms 100.4MB 843ms 157ms pypy 3.10.14
python 8.py timeout 0.0ms 18.3MB 67ms 20ms pyston 3.8.12

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
python 8.py timeout 0.0ms 16.4MB 110ms 20ms cpython 3.13.0
python 8.py timeout 0.0ms 97.6MB 1480ms 487ms pypy 3.10.14
python 8.py timeout 0.0ms 17.5MB 137ms 43ms pyston 3.8.12

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
python 8-m.py 1978ms 11ms 94.6MB 6323ms 333ms pypy 3.10.14
python 8.py timeout 0.0ms 14.1MB 243ms 43ms cpython 3.13.0
python 8.py timeout 0.0ms 17.2MB 390ms 117ms pyston 3.8.12