Javascript VS Crystal benchmarks

Current benchmark data was generated on Thu Jul 13 2023, 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
javascript 1.js 1144ms 13ms 191.4MB 1403ms 47ms bun 0.6.14
crystal 1.cr 1788ms 5.5ms 64.4MB 1767ms 10ms crystal 1.9.0
javascript 1.js 3424ms 30ms 266.2MB 2693ms 1280ms node 20.4.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 116ms 4.2ms 105.5MB 107ms 13ms bun 0.6.14
crystal 1.cr 139ms 2.3ms 11.3MB 127ms 0ms crystal 1.9.0
javascript 1.js 174ms 4.1ms 68.2MB 153ms 27ms node 20.4.0

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 1819ms 61ms 20.4MB 1783ms 17ms crystal 1.9.0
javascript 1.js 2222ms 17ms 79.9MB 2267ms 43ms node 20.4.0
javascript 1.js 3195ms 143ms 121.5MB 3190ms 27ms bun 0.6.14

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 97ms 1.5ms 7.7MB 77ms 10ms crystal 1.9.0
javascript 1.js 215ms 3.0ms 61.3MB 187ms 27ms node 20.4.0
javascript 1.js 235ms 6.8ms 102.0MB 240ms 13ms bun 0.6.14

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 80ms 0.7ms 7.2MB 63ms 7ms crystal 1.9.0
javascript 1.js 390ms 4.2ms 55.4MB 400ms 20ms node 20.4.0
javascript 1.js 398ms 2.8ms 100.1MB 367ms 20ms bun 0.6.14

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 29ms 0.7ms 5.4MB 17ms 3ms crystal 1.9.0
javascript 1.js 184ms 1.7ms 51.6MB 207ms 20ms node 20.4.0
javascript 1.js 419ms 3.1ms 88.0MB 393ms 17ms bun 0.6.14

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 2.3ms 0.5ms 3.0MB 0ms 0ms crystal 1.9.0
javascript 1.js 16ms 0.7ms 52.2MB 0ms 10ms bun 0.6.14
javascript 1.js 44ms 4.7ms 40.9MB 26ms 8ms node 20.4.0

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.bun.js 139ms 5.3ms 89.8MB 77ms 53ms bun 0.6.14
javascript 1.js 3174ms 186ms 211.2MB 3457ms 773ms node 20.4.0
crystal 1.cr 3497ms 61ms 192.3MB 360ms 360ms crystal 1.9.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.bun.js 99ms 7.1ms 76.1MB 27ms 27ms bun 0.6.14
javascript 1.js 400ms 7.6ms 69.7MB 387ms 100ms node 20.4.0
crystal 1.cr 1284ms 15ms 52.6MB 47ms 50ms crystal 1.9.0

json-serde

Input: sample 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 128ms 2.1ms 95.6MB 103ms 17ms bun 0.6.14
javascript 1.js 152ms 5.3ms 63.3MB 127ms 23ms node 20.4.0

Input: canada 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 698ms 1.7ms 259.9MB 680ms 40ms bun 0.6.14
javascript 1.js 1025ms 5.8ms 221.6MB 1020ms 87ms node 20.4.0

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 54ms 0.3ms 3.0MB 50ms 0ms crystal 1.9.0
crystal 1.cr 143ms 54ms 3.0MB 130ms 0ms crystal 1.9.0
javascript 2.js 372ms 9.7ms 53.0MB 350ms 20ms node 20.4.0
javascript 1.js 556ms 2.7ms 148.0MB 543ms 30ms bun 0.6.14
javascript 1.js 710ms 8.8ms 51.8MB 687ms 23ms node 20.4.0
javascript 2.js 775ms 1.4ms 112.6MB 790ms 20ms bun 0.6.14

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 213ms 80ms 3.0MB 193ms 0ms crystal 1.9.0
crystal 1.cr 273ms 1.2ms 3.0MB 263ms 0ms crystal 1.9.0
javascript 2.js 1001ms 3.1ms 63.0MB 973ms 23ms node 20.4.0
javascript 1.js 1591ms 6.1ms 173.4MB 1610ms 30ms bun 0.6.14
javascript 1.js 2007ms 8.0ms 58.4MB 1987ms 20ms node 20.4.0
javascript 2.js 2225ms 22ms 120.8MB 2230ms 27ms bun 0.6.14

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 29ms 5.2ms 3.0MB 20ms 0ms crystal 1.9.0
crystal 1.cr 49ms 4.2ms 3.1MB 37ms 0ms crystal 1.9.0
javascript 2.js 207ms 5.6ms 46.6MB 187ms 20ms node 20.4.0
javascript 1.js 224ms 2.5ms 48.7MB 200ms 23ms node 20.4.0
javascript 1.js 283ms 1.9ms 118.4MB 270ms 20ms bun 0.6.14
javascript 2.js 421ms 4.8ms 107.6MB 423ms 20ms bun 0.6.14

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 740ms 11ms 158.0MB 823ms 20ms bun 0.6.14
javascript 1.js 761ms 9.1ms 120.7MB 763ms 50ms node 20.4.0
crystal 1.cr 1237ms 24ms 64.4MB 1210ms 13ms crystal 1.9.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 173ms 3.3ms 110.2MB 153ms 23ms bun 0.6.14
javascript 1.js 217ms 3.0ms 88.2MB 197ms 30ms node 20.4.0
crystal 1.cr 226ms 8.6ms 17.5MB 210ms 0ms crystal 1.9.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 450ms 0.3ms 2.9MB 437ms 0ms crystal 1.9.0
crystal 1.cr 468ms 29ms 3.0MB 457ms 0ms crystal 1.9.0
javascript 6.js 611ms 7.4ms 45.7MB 590ms 17ms node 20.4.0
javascript 6.js 1018ms 11ms 74.0MB 1010ms 0ms bun 0.6.14

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 48ms 0.1ms 2.9MB 40ms 0ms crystal 1.9.0
crystal 1.cr 48ms 0.8ms 3.0MB 40ms 0ms crystal 1.9.0
javascript 6.js 111ms 1.6ms 45.8MB 90ms 17ms node 20.4.0
javascript 6.js 123ms 0.5ms 75.7MB 120ms 7ms bun 0.6.14

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 2985ms 3.9ms 105.5MB 3003ms 13ms bun 0.6.14
javascript 1.js 3180ms 8.4ms 48.8MB 3170ms 23ms node 20.4.0

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 1.js 768ms 1.3ms 103.4MB 770ms 17ms bun 0.6.14
javascript 1.js 845ms 3.4ms 47.5MB 837ms 17ms node 20.4.0

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 2576ms 68ms 6.6MB 2557ms 3ms crystal 1.9.0
javascript 3.js timeout 0.0ms 77.2MB 4353ms 647ms node 20.4.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 583ms 11ms 5.4MB 570ms 0ms crystal 1.9.0
javascript 3.js 1642ms 5.5ms 60.9MB 1547ms 107ms node 20.4.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 6-m.js 2651ms 11ms 66.6MB 5087ms 50ms node 20.4.0
crystal 1.cr timeout 0.0ms 4.4MB 4983ms 0ms crystal 1.9.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 6-m.js 768ms 3.5ms 64.1MB 1393ms 47ms node 20.4.0
crystal 1.cr 1433ms 0.2ms 3.9MB 1423ms 0ms crystal 1.9.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
javascript 6-m.js 303ms 6.8ms 68.3MB 477ms 33ms node 20.4.0
crystal 1.cr 364ms 0.3ms 4.0MB 350ms 0ms crystal 1.9.0