Typescript VS Go benchmarks

Current benchmark data was generated on Thu Sep 22 2022, full log can be found HERE

CONTRIBUTIONS are WELCOME!

[x86_64][2 cores] Intel(R) Xeon(R) Platinum 8370C CPU @ 2.80GHz (Model 106)

* -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 3006ms 7.3ms 46.0MB 4327ms 47ms go 1.19.1
typescript 1.ts 3386ms 187ms 200.3MB 3387ms 530ms deno 1.25.3
go 1.go 4239ms 23ms 37.9MB 4220ms 0ms tinygo 0.25.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 1.ts 130ms 1.1ms 51.3MB 123ms 7ms deno 1.25.3
go 1.go 259ms 1.5ms 8.1MB 337ms 3ms go 1.19.1
go 1.go 349ms 0.6ms 6.0MB 340ms 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 787ms 149ms 13.6MB 1523ms 3ms go 1.19.1
go 1.go 1694ms 7.1ms 257.2MB 1627ms 53ms tinygo 0.25.0
typescript 1.ts 2091ms 27ms 71.6MB 2090ms 27ms deno 1.25.3

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-m.go 57ms 8.6ms 5.4MB 87ms 0ms go 1.19.1
typescript 1.ts 202ms 11ms 46.0MB 163ms 7ms deno 1.25.3
go 1.go 272ms 0.3ms 68.7MB 247ms 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 242ms 1.6ms 2.9MB 440ms 0ms go 1.19.1
typescript 1.ts 4338ms 41ms 55.4MB 4160ms 157ms deno 1.25.3

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 30ms 0.1ms 2.9MB 40ms 0ms go 1.19.1
typescript 1.ts 462ms 5.7ms 47.6MB 443ms 20ms deno 1.25.3

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 1.6ms 0.9ms 0.0MB 0ms 0ms tinygo 0.25.0
go 1.go 2.6ms 0.5ms 2.9MB 0ms 0ms go 1.19.1
typescript 1.ts 22ms 0.5ms 32.8MB 10ms 0ms deno 1.25.3

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-http2.go 172ms 6.5ms 55.9MB 260ms 40ms go 1.19.1
go 2-m.go 551ms 17ms 170.1MB 487ms 367ms go 1.19.1
go 1-m.go 613ms 42ms 165.7MB 613ms 370ms go 1.19.1
typescript 2.ts 1082ms 28ms 138.2MB 1277ms 330ms deno 1.25.3
typescript 1.ts 1265ms 234ms 142.6MB 1260ms 327ms deno 1.25.3
typescript 1-http2.ts 1358ms 56ms 143.7MB 1540ms 367ms deno 1.25.3
typescript 2-tls.ts timeout 0.0ms 0.0MB 0ms 0ms deno 1.25.3

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1-http2.go 31ms 20ms 22.7MB 45ms 5ms go 1.19.1
go 1.go 131ms 9.7ms 38.4MB 73ms 67ms go 1.19.1
go 2.go 135ms 3.5ms 39.1MB 83ms 60ms go 1.19.1
typescript 2.ts 226ms 9.5ms 76.1MB 183ms 50ms deno 1.25.3
typescript 1.ts 234ms 2.2ms 78.2MB 157ms 80ms deno 1.25.3
typescript 1-http2.ts 372ms 8.2ms 77.9MB 250ms 70ms deno 1.25.3
typescript 2-tls.ts 407ms 1.2ms 84.4MB 353ms 63ms deno 1.25.3

json-serde

Input: sample 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 2-ffi.go 71ms 3.9ms 45.0MB 57ms 3ms go 1.19.1
typescript 1.ts 146ms 4.7ms 65.8MB 133ms 13ms deno 1.25.3
go 1.go 171ms 1.4ms 18.7MB 157ms 3ms go 1.19.1

Input: canada 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 2-ffi.go 407ms 3.6ms 165.2MB 370ms 113ms go 1.19.1
go 1.go 1043ms 0.4ms 109.0MB 1030ms 47ms go 1.19.1
typescript 1.ts 1142ms 5.7ms 265.5MB 1240ms 80ms deno 1.25.3

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 166ms 1.1ms 0.3MB 160ms 0ms tinygo 0.25.0
go 3.go 175ms 0.9ms 2.9MB 160ms 0ms go 1.19.1
typescript 2.ts 693ms 34ms 45.5MB 687ms 3ms deno 1.25.3
typescript 1.ts 1091ms 2.3ms 45.4MB 1080ms 7ms deno 1.25.3

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 491ms 0.4ms 0.3MB 480ms 0ms tinygo 0.25.0
go 3.go 513ms 2.7ms 3.4MB 500ms 0ms go 1.19.1
typescript 2.ts 1943ms 11ms 53.2MB 1927ms 13ms deno 1.25.3
typescript 1.ts 3202ms 2.6ms 51.7MB 3183ms 7ms deno 1.25.3

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 3.go 81ms 1.2ms 0.0MB 70ms 0ms tinygo 0.25.0
go 3.go 94ms 1.0ms 3.9MB 83ms 0ms go 1.19.1
typescript 2.ts 339ms 2.5ms 40.5MB 333ms 0ms deno 1.25.3
typescript 1.ts 370ms 0.3ms 37.7MB 357ms 3ms deno 1.25.3

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 1.ts 649ms 3.4ms 90.5MB 667ms 30ms deno 1.25.3
go 1.go 1976ms 5.3ms 48.1MB 2803ms 43ms go 1.19.1
go 2.go 2305ms 5.9ms 41.3MB 3270ms 43ms go 1.19.1
go 1.go 3286ms 4.0ms 212.1MB 3233ms 33ms 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 166ms 1.1ms 59.8MB 170ms 17ms deno 1.25.3
go 1.go 413ms 2.9ms 12.3MB 567ms 13ms go 1.19.1
go 2.go 485ms 2.0ms 13.0MB 663ms 17ms go 1.19.1
go 1.go 792ms 1.5ms 52.1MB 773ms 3ms tinygo 0.25.0
go 2.go 1083ms 3.6ms 39.4MB 1057ms 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 455ms 2.1ms 2.9MB 443ms 0ms go 1.19.1
typescript 6.ts 630ms 0.8ms 38.6MB 617ms 7ms deno 1.25.3
go 1.go 843ms 0.9ms 0.0MB 830ms 0ms tinygo 0.25.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 1.go 50ms 1.4ms 2.9MB 40ms 0ms go 1.19.1
go 1.go 88ms 2.5ms 0.0MB 80ms 0ms tinygo 0.25.0
typescript 6.ts 91ms 1.3ms 36.2MB 77ms 7ms deno 1.25.3

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 8.go 1424ms 4.4ms 8.5MB 1400ms 7ms go 1.19.1
typescript 3.ts timeout 0.0ms 0.0MB 0ms 0ms deno 1.25.3

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 8.go 341ms 0.8ms 8.4MB 323ms 3ms go 1.19.1
typescript 3.ts 1526ms 2.8ms 57.7MB 1503ms 90ms deno 1.25.3

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 0-ffi.go 171ms 1.4ms 7.9MB 157ms 3ms go 1.19.1
typescript 1.ts 2614ms 5.5ms 39.7MB 2623ms 3ms deno 1.25.3

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 0-ffi.go 56ms 0.2ms 9.6MB 43ms 0ms go 1.19.1
typescript 1.ts 697ms 16ms 39.4MB 690ms 10ms deno 1.25.3

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 2511ms 29ms 5.4MB 4843ms 7ms go 1.19.1
go 1.go 4887ms 5.0ms 5.5MB 4870ms 3ms 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.25.3

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
go 4-m.go 630ms 0.5ms 4.9MB 1200ms 0ms go 1.19.1
go 1.go 1229ms 3.9ms 2.9MB 1213ms 3ms go 1.19.1
typescript 7.ts 1279ms 2.0ms 38.5MB 1270ms 3ms deno 1.25.3
go 1.go 2577ms 1.0ms 0.0MB 2560ms 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 166ms 0.9ms 4.9MB 293ms 0ms go 1.19.1
go 1.go 309ms 0.2ms 2.9MB 300ms 0ms go 1.19.1
typescript 7.ts 345ms 1.5ms 36.1MB 330ms 7ms deno 1.25.3
go 1.go 648ms 0.7ms 0.0MB 637ms 0ms tinygo 0.25.0