Go VS Typescript benchmarks

Current benchmark data was generated on Fri Sep 30 2022, full log can be found HERE

CONTRIBUTIONS are WELCOME!

[x86_64][2 cores] Intel(R) Xeon(R) Platinum 8272CL CPU @ 2.60GHz (Model 85)

* -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.go 3077ms 30ms 45.6MB 4420ms 73ms go 1.19.1
typescript 1.ts 3971ms 6.6ms 200.5MB 3913ms 723ms deno 1.26.0
go 1.go 4620ms 32ms 38.6MB 4597ms 7ms tinygo 0.25.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 1.ts 158ms 15ms 52.9MB 150ms 13ms deno 1.26.0
go 1.go 259ms 1.6ms 8.0MB 343ms 3ms go 1.19.1
go 1.go 368ms 2.5ms 5.9MB 357ms 0ms tinygo 0.25.0

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 768ms 24ms 15.4MB 1480ms 0ms go 1.19.1
go 1.go 1998ms 12ms 257.5MB 1930ms 53ms tinygo 0.25.0
typescript 1.ts 2072ms 3.7ms 68.9MB 2097ms 33ms deno 1.26.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 68ms 8.6ms 6.9MB 103ms 0ms go 1.19.1
typescript 1.ts 176ms 1.7ms 42.3MB 163ms 7ms deno 1.26.0
go 1.go 300ms 1.1ms 68.6MB 270ms 10ms tinygo 0.25.0

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 161ms 0.6ms 8.4MB 150ms 3ms go 1.19.1

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 50ms 2.1ms 10.0MB 37ms 0ms go 1.19.1

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 1193ms 22ms 5.0MB 2273ms 3ms go 1.19.1
go 3.go 2702ms 4.8ms 50.1MB 2673ms 10ms tinygo 0.25.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 124ms 0.6ms 5.0MB 180ms 0ms go 1.19.1
go 3.go 298ms 1.6ms 47.6MB 270ms 10ms tinygo 0.25.0

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3-m.go 207ms 4.9ms 2.9MB 370ms 0ms go 1.19.1
typescript 1.ts 2199ms 42ms 39.2MB 2057ms 127ms deno 1.26.0

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 27ms 1.4ms 4.9MB 30ms 0ms go 1.19.1
typescript 1.ts 289ms 59ms 39.0MB 257ms 10ms deno 1.26.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 2.1ms 0.8ms 2.0MB 0ms 0ms tinygo 0.25.0
go 1.go 3.4ms 0.5ms 2.9MB 0ms 0ms go 1.19.1
typescript 1.ts 30ms 2.3ms 32.6MB 18ms 0ms deno 1.26.0

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-http2.go 189ms 17ms 58.5MB 283ms 43ms go 1.19.1
go 2-m.go 677ms 60ms 172.2MB 630ms 440ms go 1.19.1
go 1-m.go 689ms 44ms 172.9MB 677ms 437ms go 1.19.1
typescript 1.ts 1217ms 43ms 136.7MB 1400ms 363ms deno 1.26.0
typescript 2.ts 1218ms 36ms 139.0MB 1423ms 353ms deno 1.26.0
typescript 1-http2.ts 1557ms 78ms 142.7MB 1750ms 400ms deno 1.26.0
typescript 2-tls.ts timeout 0.0ms 0.0MB 0ms 0ms deno 1.26.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-http2.go 49ms 5.1ms 24.5MB 33ms 23ms go 1.19.1
go 2.go 136ms 12ms 37.0MB 90ms 57ms go 1.19.1
go 1.go 147ms 3.4ms 38.8MB 93ms 63ms go 1.19.1
typescript 2.ts 255ms 15ms 73.7MB 193ms 70ms deno 1.26.0
typescript 1.ts 263ms 6.7ms 77.8MB 193ms 70ms deno 1.26.0
typescript 1-http2.ts 286ms 7.6ms 77.0MB 237ms 63ms deno 1.26.0
typescript 2-tls.ts 412ms 11ms 84.0MB 350ms 67ms deno 1.26.0

json-serde

Input: sample 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 2-ffi.go 76ms 3.0ms 44.6MB 60ms 10ms go 1.19.1
go 1.go 182ms 3.9ms 18.8MB 163ms 7ms go 1.19.1
typescript 1.ts 183ms 28ms 67.6MB 137ms 23ms deno 1.26.0

Input: canada 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 2-ffi.go 378ms 4.0ms 175.4MB 363ms 67ms go 1.19.1
go 1.go 1055ms 7.7ms 103.3MB 1027ms 47ms go 1.19.1
typescript 1.ts 1248ms 4.5ms 263.5MB 1363ms 97ms deno 1.26.0

knucleotide

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 7-m.go 1349ms 13ms 41.6MB 2507ms 27ms go 1.19.1

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 7-m.go 220ms 4.9ms 22.3MB 340ms 23ms go 1.19.1

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 160ms 0.5ms 0.3MB 150ms 0ms tinygo 0.25.0
go 3.go 170ms 0.3ms 2.8MB 157ms 0ms go 1.19.1
typescript 2.ts 672ms 5.4ms 45.0MB 663ms 7ms deno 1.26.0
typescript 1.ts 994ms 2.6ms 44.9MB 983ms 3ms deno 1.26.0

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 475ms 1.0ms 0.3MB 460ms 0ms tinygo 0.25.0
go 3.go 490ms 2.3ms 2.9MB 480ms 0ms go 1.19.1
typescript 2.ts 1904ms 1.7ms 53.2MB 1883ms 20ms deno 1.26.0
typescript 1.ts 2934ms 9.8ms 52.2MB 2893ms 13ms deno 1.26.0

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 79ms 0.2ms 2.0MB 70ms 0ms tinygo 0.25.0
go 3.go 90ms 0.3ms 3.6MB 80ms 0ms go 1.19.1
typescript 2.ts 342ms 0.9ms 39.0MB 330ms 10ms deno 1.26.0
typescript 1.ts 368ms 1.6ms 38.7MB 353ms 3ms deno 1.26.0

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 3793ms 4.0ms 6.8MB 3783ms 0ms go 1.19.1
go 1.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 161ms 1.9ms 2.8MB 147ms 0ms go 1.19.1
go 1.go 328ms 0.2ms 0.0MB 320ms 0ms tinygo 0.25.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 1.ts 744ms 8.4ms 91.8MB 763ms 30ms deno 1.26.0
go 1.go 2053ms 15ms 38.2MB 2917ms 47ms go 1.19.1
go 2.go 2357ms 19ms 41.1MB 3357ms 67ms go 1.19.1
go 1.go 3664ms 2.2ms 213.2MB 3600ms 47ms tinygo 0.25.0
go 2.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 1.ts 192ms 3.1ms 59.4MB 190ms 17ms deno 1.26.0
go 1.go 426ms 5.0ms 12.5MB 583ms 13ms go 1.19.1
go 2.go 492ms 3.3ms 14.1MB 680ms 10ms go 1.19.1
go 1.go 867ms 5.2ms 51.6MB 840ms 13ms tinygo 0.25.0
go 2.go 1183ms 11ms 39.3MB 1150ms 10ms tinygo 0.25.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 505ms 1.8ms 2.9MB 490ms 0ms go 1.19.1
go 1.go 706ms 0.5ms 0.0MB 690ms 0ms tinygo 0.25.0
typescript 6.ts 749ms 18ms 38.1MB 733ms 3ms deno 1.26.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 56ms 3.1ms 2.9MB 47ms 0ms go 1.19.1
go 1.go 73ms 0.5ms 0.0MB 60ms 0ms tinygo 0.25.0
typescript 6.ts 111ms 1.6ms 37.8MB 103ms 3ms deno 1.26.0

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 2.go 689ms 0.1ms 17.9MB 673ms 0ms tinygo 0.25.0
go 2.go 907ms 5.7ms 20.0MB 890ms 7ms go 1.19.1
go 1.go 996ms 17ms 73.6MB 967ms 13ms go 1.19.1
go 1.go 1089ms 31ms 42.3MB 1073ms 0ms tinygo 0.25.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 128ms 5.9ms 22.2MB 110ms 3ms go 1.19.1
go 1.go 132ms 5.6ms 13.6MB 123ms 0ms tinygo 0.25.0
go 2.go 159ms 0.6ms 5.1MB 150ms 0ms tinygo 0.25.0
go 2.go 210ms 2.2ms 7.5MB 197ms 0ms go 1.19.1

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 8.go 1344ms 1.6ms 8.5MB 1327ms 3ms go 1.19.1
typescript 3.ts timeout 0.0ms 0.0MB 0ms 0ms deno 1.26.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 8.go 323ms 1.2ms 8.4MB 307ms 3ms go 1.19.1
typescript 3.ts 1499ms 24ms 59.1MB 1463ms 50ms deno 1.26.0

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go timeout 0.0ms 0.0MB 0ms 0ms go 1.19.1
go 3.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 2402ms 8.4ms 19.1MB 2383ms 27ms go 1.19.1
go 3.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 0-ffi.go 150ms 0.8ms 9.6MB 137ms 3ms go 1.19.1
typescript 1.ts 3209ms 21ms 40.8MB 3197ms 3ms deno 1.26.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 0-ffi.go 51ms 1.6ms 10.0MB 37ms 0ms go 1.19.1
typescript 1.ts 841ms 3.5ms 39.0MB 837ms 13ms deno 1.26.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 2208ms 2.6ms 5.4MB 4297ms 0ms go 1.19.1
go 1.go 4328ms 2.9ms 5.4MB 4320ms 0ms go 1.19.1
go 1.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0
typescript 7.ts timeout 0.0ms 0.0MB 0ms 0ms deno 1.26.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 562ms 0.5ms 2.9MB 1063ms 0ms go 1.19.1
go 1.go 1087ms 1.7ms 2.9MB 1080ms 0ms go 1.19.1
typescript 7.ts 1358ms 1.2ms 38.1MB 1343ms 7ms deno 1.26.0
go 1.go timeout 0.0ms 0.0MB 0ms 0ms tinygo 0.25.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 151ms 0.3ms 2.9MB 267ms 3ms go 1.19.1
go 1.go 276ms 3.0ms 2.9MB 267ms 0ms go 1.19.1
typescript 7.ts 372ms 2.0ms 37.9MB 353ms 7ms deno 1.26.0
go 1.go 1639ms 1.0ms 0.0MB 1630ms 0ms tinygo 0.25.0