Javascript VS Crystal benchmarks

Current benchmark data was generated on Wed May 25 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
crystal 1.cr 1959ms 5.7ms 64.5MB 2317ms 27ms crystal 1.4.1
javascript 1.js 4218ms 14ms 265.6MB 2980ms 1580ms node 18.2.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 143ms 1.4ms 12.9MB 150ms 0ms crystal 1.4.1
javascript 1.js 237ms 0.8ms 80.5MB 213ms 33ms node 18.2.0

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 2268ms 8.4ms 22.3MB 2203ms 47ms crystal 1.4.1
javascript 1.js 2607ms 120ms 76.4MB 2667ms 50ms node 18.2.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 126ms 3.3ms 7.6MB 110ms 3ms crystal 1.4.1
javascript 1.js 237ms 1.3ms 57.5MB 210ms 23ms node 18.2.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 3.8ms 0.8ms 2.8MB 0ms 0ms crystal 1.4.1
javascript 1.js 50ms 3.0ms 37.6MB 36ms 4ms node 18.2.0

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 3786ms 625ms 130.5MB 420ms 280ms crystal 1.4.1
javascript 1.js timeout 0.0ms 0.0MB 0ms 0ms node 18.2.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 399ms 7.4ms 68.0MB 357ms 87ms node 18.2.0
crystal 1.cr 1184ms 111ms 35.7MB 50ms 47ms crystal 1.4.1

json-serde

Input: sample 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 180ms 2.5ms 70.0MB 153ms 23ms node 18.2.0

Input: canada 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 1217ms 3.5ms 285.3MB 1183ms 150ms node 18.2.0

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 63ms 1.8ms 3.0MB 50ms 0ms crystal 1.4.1
crystal 1.cr 110ms 0.2ms 3.1MB 100ms 0ms crystal 1.4.1
javascript 2.js 849ms 2.0ms 55.0MB 833ms 7ms node 18.2.0
javascript 1.js 1145ms 3.1ms 57.1MB 1117ms 20ms node 18.2.0

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 176ms 0.2ms 4.9MB 160ms 0ms crystal 1.4.1
crystal 1.cr 323ms 4.4ms 5.1MB 310ms 0ms crystal 1.4.1
javascript 2.js 2393ms 20ms 58.1MB 2380ms 13ms node 18.2.0
javascript 1.js 3152ms 220ms 56.9MB 3113ms 30ms node 18.2.0

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 31ms 2.3ms 3.1MB 20ms 0ms crystal 1.4.1
crystal 1.cr 57ms 1.1ms 5.1MB 47ms 0ms crystal 1.4.1
javascript 2.js 440ms 2.4ms 46.5MB 423ms 7ms node 18.2.0
javascript 1.js 465ms 0.8ms 42.7MB 443ms 17ms node 18.2.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 1071ms 1.7ms 117.0MB 1107ms 53ms node 18.2.0
crystal 1.cr 1471ms 5.0ms 64.3MB 1713ms 20ms crystal 1.4.1

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 246ms 2.3ms 17.7MB 260ms 13ms crystal 1.4.1
javascript 1.js 302ms 1.3ms 84.4MB 290ms 33ms node 18.2.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 593ms 0.5ms 3.2MB 577ms 0ms crystal 1.4.1
crystal 2.cr 623ms 0.5ms 3.4MB 610ms 0ms crystal 1.4.1
javascript 6.js 721ms 41ms 42.6MB 703ms 3ms node 18.2.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 65ms 1.7ms 5.0MB 53ms 0ms crystal 1.4.1
crystal 2.cr 67ms 1.8ms 3.2MB 57ms 0ms crystal 1.4.1
javascript 6.js 132ms 11ms 42.5MB 103ms 13ms node 18.2.0

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 2792ms 50ms 8.8MB 3063ms 283ms crystal 1.4.1
javascript 3.js timeout 0.0ms 0.0MB 0ms 0ms node 18.2.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 645ms 7.0ms 7.5MB 663ms 83ms crystal 1.4.1
javascript 3.js 1675ms 7.6ms 58.4MB 1663ms 13ms node 18.2.0

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 4145ms 23ms 47.6MB 4160ms 27ms node 18.2.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 1049ms 70ms 46.8MB 1057ms 10ms node 18.2.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 6-m.js 2983ms 4.9ms 67.0MB 5593ms 30ms node 18.2.0
crystal 1.cr timeout 0.0ms 0.0MB 0ms 0ms crystal 1.4.1

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 6-m.js 923ms 9.4ms 65.4MB 1623ms 27ms node 18.2.0
crystal 1.cr 1386ms 101ms 6.1MB 1370ms 0ms crystal 1.4.1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 381ms 1.7ms 3.8MB 370ms 0ms crystal 1.4.1
javascript 6-m.js 410ms 6.8ms 65.7MB 593ms 33ms node 18.2.0