Crystal VS Typescript 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
crystal 1.cr 1541ms 5.5ms 66.2MB 1840ms 17ms crystal 1.5.1
typescript 1.ts 3386ms 187ms 200.3MB 3387ms 530ms deno 1.25.3

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
crystal 1.cr 131ms 0.2ms 13.1MB 140ms 0ms crystal 1.5.1

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 1972ms 20ms 22.3MB 1920ms 30ms crystal 1.5.1
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
crystal 1.cr 110ms 4.1ms 7.6MB 97ms 3ms crystal 1.5.1
typescript 1.ts 202ms 11ms 46.0MB 163ms 7ms deno 1.25.3

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 85ms 3.4ms 9.2MB 70ms 0ms crystal 1.5.1

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 31ms 0.4ms 7.0MB 20ms 0ms crystal 1.5.1

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 3970ms 6.7ms 3.0MB 3957ms 0ms crystal 1.5.1

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 323ms 0.4ms 3.0MB 310ms 0ms crystal 1.5.1

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 859ms 3.2ms 5.6MB 750ms 97ms crystal 1.5.1
crystal 1.cr 1059ms 1.3ms 16.7MB 903ms 140ms crystal 1.5.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
crystal 2.cr 91ms 1.0ms 5.3MB 70ms 3ms crystal 1.5.1
crystal 1.cr 111ms 0.2ms 4.6MB 87ms 10ms crystal 1.5.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
crystal 1.cr 4.6ms 2.2ms 3.1MB 0ms 0ms crystal 1.5.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
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
crystal 1.cr 3369ms 198ms 152.7MB 297ms 283ms crystal 1.5.1
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
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
crystal 1.cr 1173ms 102ms 32.3MB 40ms 40ms crystal 1.5.1

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 61ms 0.9ms 5.0MB 50ms 0ms crystal 1.5.1
crystal 1.cr 108ms 0.4ms 3.0MB 97ms 0ms crystal 1.5.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
crystal 0-unsafe.cr 174ms 0.5ms 3.1MB 160ms 0ms crystal 1.5.1
crystal 1.cr 312ms 1.3ms 3.0MB 300ms 0ms crystal 1.5.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
crystal 0-unsafe.cr 31ms 0.8ms 5.0MB 20ms 0ms crystal 1.5.1
crystal 1.cr 55ms 2.1ms 3.1MB 47ms 0ms crystal 1.5.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

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 994ms 0.9ms 7.6MB 980ms 0ms crystal 1.5.1

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 46ms 0.5ms 6.4MB 40ms 0ms crystal 1.5.1

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
crystal 1.cr 1083ms 49ms 64.3MB 1230ms 23ms crystal 1.5.1

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
crystal 1.cr 207ms 6.9ms 17.5MB 223ms 3ms crystal 1.5.1

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 516ms 4.8ms 2.9MB 500ms 0ms crystal 1.5.1
crystal 2.cr 540ms 0.7ms 2.9MB 530ms 0ms crystal 1.5.1
typescript 6.ts 630ms 0.8ms 38.6MB 617ms 7ms deno 1.25.3

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 56ms 1.6ms 3.0MB 50ms 0ms crystal 1.5.1
crystal 2.cr 60ms 2.8ms 2.9MB 43ms 0ms crystal 1.5.1
typescript 6.ts 91ms 1.3ms 36.2MB 77ms 7ms deno 1.25.3

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 467ms 2.2ms 9.8MB 453ms 0ms crystal 1.5.1
crystal 1.cr 851ms 16ms 42.7MB 827ms 7ms crystal 1.5.1

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 108ms 0.2ms 4.4MB 97ms 0ms crystal 1.5.1
crystal 1.cr 151ms 1.6ms 12.9MB 137ms 0ms crystal 1.5.1

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 2779ms 53ms 9.0MB 3030ms 280ms crystal 1.5.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
crystal 1.cr 644ms 5.5ms 5.3MB 670ms 70ms crystal 1.5.1
typescript 3.ts 1526ms 2.8ms 57.7MB 1503ms 90ms deno 1.25.3

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 2474ms 0.8ms 196.1MB 2397ms 57ms crystal 1.5.1

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 256ms 2.5ms 24.5MB 237ms 3ms crystal 1.5.1

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr timeout 0.0ms 0.0MB 0ms 0ms crystal 1.5.1
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
typescript 7.ts 1279ms 2.0ms 38.5MB 1270ms 3ms deno 1.25.3
crystal 1.cr 1510ms 2.5ms 5.8MB 1493ms 0ms crystal 1.5.1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 7.ts 345ms 1.5ms 36.1MB 330ms 7ms deno 1.25.3
crystal 1.cr 382ms 1.3ms 3.8MB 370ms 0ms crystal 1.5.1