Typescript VS Crystal 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
crystal 1.cr 1363ms 1.9ms 64.6MB 1337ms 10ms crystal 1.11.2
typescript 1-m.ts 1432ms 22ms 190.5MB 2300ms 300ms deno 1.40.2

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 104ms 0.1ms 11.4MB 93ms 0ms crystal 1.11.2
typescript 1.ts 138ms 0.4ms 95.4MB 133ms 37ms deno 1.40.2

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 1.ts 1435ms 3.7ms 90.9MB 1497ms 53ms deno 1.40.2
crystal 1.cr 1546ms 60ms 20.6MB 1490ms 40ms crystal 1.11.2

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 82ms 3.7ms 7.6MB 60ms 13ms crystal 1.11.2
typescript 1.ts 155ms 2.8ms 71.7MB 133ms 27ms deno 1.40.2

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 530ms 2.1ms 3.8MB 430ms 83ms crystal 1.11.2
crystal 1.cr 695ms 1.7ms 14.9MB 580ms 100ms crystal 1.11.2
typescript 1.ts 2930ms 24ms 60.1MB 2793ms 147ms deno 1.40.2

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 57ms 1.0ms 3.6MB 40ms 3ms crystal 1.11.2
crystal 1.cr 74ms 1.2ms 4.8MB 57ms 3ms crystal 1.11.2
typescript 1.ts 328ms 1.0ms 59.5MB 313ms 27ms deno 1.40.2

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 2.2ms 0.2ms 3.1MB 0ms 0ms crystal 1.11.2
typescript 1.ts 27ms 0.7ms 51.1MB 8ms 4ms deno 1.40.2

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 2-m.ts 950ms 13ms 168.7MB 1003ms 447ms deno 1.40.2
typescript 1-m.ts 982ms 39ms 167.3MB 1020ms 480ms deno 1.40.2
typescript 2-tls.ts 1138ms 20ms 170.2MB 1173ms 490ms deno 1.40.2
typescript 1-http2.ts 1144ms 47ms 167.1MB 1200ms 470ms deno 1.40.2
crystal 1.cr 3454ms 121ms 214.8MB 293ms 433ms crystal 1.11.2

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 2.ts 223ms 8.6ms 91.5MB 120ms 100ms deno 1.40.2
typescript 1.ts 231ms 16ms 95.2MB 143ms 77ms deno 1.40.2
typescript 1-http2.ts 271ms 15ms 90.4MB 173ms 87ms deno 1.40.2
typescript 2-tls.ts 385ms 15ms 96.0MB 270ms 103ms deno 1.40.2
crystal 1.cr 1157ms 109ms 53.9MB 27ms 77ms crystal 1.11.2

json-serde

Input: sample 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 1.ts 186ms 4.1ms 93.9MB 173ms 37ms deno 1.40.2

Input: canada 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 1.ts 1301ms 3.0ms 435.2MB 1487ms 120ms deno 1.40.2

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 38ms 0.7ms 3.3MB 30ms 0ms crystal 1.11.2
crystal 1.cr 67ms 1.0ms 3.3MB 57ms 0ms crystal 1.11.2
typescript 2.ts 267ms 4.6ms 63.9MB 250ms 17ms deno 1.40.2
typescript 1.ts 528ms 2.2ms 64.6MB 513ms 13ms deno 1.40.2

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 106ms 1.1ms 3.3MB 97ms 0ms crystal 1.11.2
crystal 1.cr 188ms 1.0ms 3.3MB 180ms 0ms crystal 1.11.2
typescript 2.ts 719ms 8.2ms 72.2MB 720ms 13ms deno 1.40.2
typescript 1.ts 1515ms 8.0ms 69.7MB 1503ms 13ms deno 1.40.2

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 20ms 1.2ms 3.1MB 10ms 0ms crystal 1.11.2
crystal 1.cr 35ms 1.1ms 3.1MB 27ms 0ms crystal 1.11.2
typescript 2.ts 142ms 0.4ms 61.9MB 133ms 10ms deno 1.40.2
typescript 1.ts 163ms 0.4ms 60.1MB 150ms 10ms deno 1.40.2

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 1.ts 554ms 0.7ms 130.9MB 633ms 73ms deno 1.40.2
crystal 1.cr 928ms 8.2ms 64.6MB 903ms 7ms crystal 1.11.2

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 1.ts 166ms 3.3ms 99.0MB 160ms 47ms deno 1.40.2
crystal 1.cr 171ms 2.6ms 17.6MB 157ms 0ms crystal 1.11.2

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 342ms 0.8ms 3.5MB 330ms 0ms crystal 1.11.2
crystal 2.cr 348ms 10ms 3.5MB 337ms 0ms crystal 1.11.2
typescript 6.ts 456ms 4.6ms 57.6MB 440ms 7ms deno 1.40.2

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 37ms 0.5ms 3.5MB 27ms 0ms crystal 1.11.2
crystal 1.cr 39ms 1.2ms 3.6MB 30ms 0ms crystal 1.11.2
typescript 6.ts 78ms 1.2ms 57.7MB 57ms 13ms deno 1.40.2

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 1944ms 14ms 6.5MB 1910ms 17ms crystal 1.11.2
typescript 3.ts timeout 0.0ms 100.6MB 4977ms 53ms deno 1.40.2

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 452ms 10ms 5.4MB 437ms 3ms crystal 1.11.2
typescript 3.ts 1268ms 11ms 86.3MB 1210ms 73ms deno 1.40.2

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 1.ts 1958ms 9.9ms 60.2MB 1957ms 13ms deno 1.40.2

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
typescript 1.ts 532ms 1.9ms 59.6MB 527ms 13ms deno 1.40.2

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 3743ms 15ms 4.8MB 3727ms 0ms crystal 1.11.2
typescript 7.ts 4066ms 156ms 59.5MB 4050ms 13ms deno 1.40.2

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 945ms 4.4ms 4.4MB 933ms 0ms crystal 1.11.2
typescript 7.ts 1002ms 27ms 57.1MB 993ms 7ms deno 1.40.2

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 238ms 0.1ms 4.1MB 227ms 0ms crystal 1.11.2
typescript 7.ts 263ms 2.7ms 57.1MB 243ms 10ms deno 1.40.2