Nim VS Julia 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
julia 4.jl 1214ms 56ms 242.2MB 1107ms 190ms julia 1.7.2
nim 2.nim 3281ms 50ms 35.2MB 3253ms 13ms nim 1.6.6
nim 2.nim 3344ms 37ms 34.2MB 3320ms 3ms nim/clang 1.6.6

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 288ms 21ms 5.7MB 273ms 0ms nim/clang 1.6.6
nim 2.nim 304ms 1.5ms 5.5MB 290ms 0ms nim 1.6.6
julia 4.jl 377ms 0.8ms 226.0MB 313ms 150ms julia 1.7.2

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim 1.6.6
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim/clang 1.6.6

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim 1.6.6
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim/clang 1.6.6

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim 1.6.6
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim/clang 1.6.6

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim 1.6.6
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim/clang 1.6.6

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 235ms 16ms 0.7MB 223ms 0ms nim 1.6.6
nim 2.nim 284ms 20ms 0.9MB 270ms 0ms nim/clang 1.6.6
julia 7-m.jl 638ms 18ms 291.4MB 853ms 153ms julia 1.7.2
nim 1.nim 642ms 2.5ms 1.0MB 560ms 70ms nim/clang 1.6.6
nim 1.nim 686ms 49ms 0.7MB 600ms 70ms nim 1.6.6

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 24ms 0.5ms 0.7MB 13ms 0ms nim 1.6.6
nim 2.nim 28ms 0.1ms 0.9MB 20ms 0ms nim/clang 1.6.6
nim 1.nim 71ms 4.9ms 0.7MB 57ms 0ms nim 1.6.6
nim 1.nim 76ms 1.0ms 0.9MB 57ms 3ms nim/clang 1.6.6
julia 7.jl 497ms 5.9ms 218.6MB 580ms 120ms julia 1.7.2

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 1.5ms 0.3ms 2.0MB 0ms 0ms nim/clang 1.6.6
nim 1.nim 1.7ms 0.6ms 0.7MB 0ms 0ms nim 1.6.6
julia 1.jl 211ms 8.7ms 171.0MB 128ms 82ms julia 1.7.2

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 899ms 3.5ms 94.4MB 447ms 420ms nim/clang 1.6.6
nim 1.nim 926ms 6.7ms 94.0MB 493ms 397ms nim 1.6.6

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 134ms 8.4ms 18.7MB 60ms 57ms nim/clang 1.6.6
nim 1.nim 145ms 1.0ms 17.8MB 70ms 60ms nim 1.6.6

lru

Input: 1000 1000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 148ms 0.5ms 0.9MB 140ms 0ms nim/clang 1.6.6
nim 2.nim 159ms 0.7ms 0.7MB 150ms 0ms nim 1.6.6
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim 1.6.6
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim/clang 1.6.6

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 422ms 30ms 0.9MB 405ms 0ms nim/clang 1.6.6
nim 2.nim 467ms 0.4ms 0.7MB 460ms 0ms nim 1.6.6
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim 1.6.6
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim/clang 1.6.6

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 65ms 0.1ms 0.9MB 53ms 0ms nim/clang 1.6.6
nim 2.nim 68ms 0.3ms 0.7MB 60ms 0ms nim 1.6.6
nim 1.nim 467ms 0.9ms 0.7MB 457ms 0ms nim 1.6.6
nim 1.nim 485ms 0.9ms 0.9MB 473ms 0ms nim/clang 1.6.6

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 485ms 35ms 4.9MB 470ms 0ms nim/clang 1.6.6
nim 1.nim 883ms 1.7ms 4.4MB 870ms 0ms nim 1.6.6

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 22ms 1.9ms 1.0MB 10ms 0ms nim/clang 1.6.6
nim 1.nim 40ms 1.2ms 0.7MB 30ms 0ms nim 1.6.6

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 1385ms 10ms 35.0MB 1363ms 3ms nim 1.6.6
nim 1.nim 1590ms 8.8ms 35.1MB 1563ms 7ms nim/clang 1.6.6

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 322ms 21ms 9.3MB 307ms 0ms nim 1.6.6
nim 1.nim 338ms 0.6ms 10.0MB 323ms 0ms nim/clang 1.6.6

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 418ms 30ms 0.9MB 403ms 0ms nim 1.6.6
nim 2.nim 437ms 11ms 0.9MB 427ms 0ms nim/clang 1.6.6
julia 7.jl 765ms 2.6ms 219.1MB 713ms 133ms julia 1.7.2

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 2.nim 43ms 4.2ms 1.0MB 33ms 0ms nim 1.6.6
nim 2.nim 46ms 0.8ms 1.0MB 37ms 0ms nim/clang 1.6.6
julia 7.jl 485ms 2.5ms 228.0MB 427ms 147ms julia 1.7.2

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
julia 1.jl 608ms 3.2ms 208.3MB 547ms 150ms julia 1.7.2
nim 2.nim 663ms 1.3ms 6.6MB 650ms 0ms nim/clang 1.6.6
nim 2.nim 776ms 0.8ms 6.1MB 760ms 0ms nim 1.6.6
nim 1.nim 1202ms 31ms 41.5MB 1180ms 7ms nim/clang 1.6.6
nim 1.nim 1255ms 71ms 40.4MB 1233ms 7ms nim 1.6.6

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 126ms 0.4ms 11.1MB 110ms 0ms nim 1.6.6
nim 1.nim 130ms 0.8ms 11.4MB 120ms 0ms nim/clang 1.6.6
nim 2.nim 152ms 1.1ms 3.3MB 140ms 0ms nim/clang 1.6.6
nim 2.nim 180ms 0.1ms 3.0MB 167ms 0ms nim 1.6.6
julia 1.jl 410ms 3.8ms 201.8MB 347ms 147ms julia 1.7.2

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
julia 3.jl 728ms 47ms 179.2MB 677ms 137ms julia 1.7.2
julia 1.jl 1708ms 59ms 256.9MB 1603ms 190ms julia 1.7.2
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim 1.6.6
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim/clang 1.6.6

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
julia 3.jl 365ms 17ms 181.2MB 320ms 130ms julia 1.7.2
julia 1.jl 925ms 30ms 258.0MB 837ms 163ms julia 1.7.2
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim 1.6.6
nim 1.nim timeout 0.0ms 0.0MB 0ms 0ms nim/clang 1.6.6

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
julia 2-m.jl 1276ms 4.7ms 197.9MB 2143ms 133ms julia 1.7.2
julia 3-m.jl 2036ms 5.8ms 210.5MB 3543ms 160ms julia 1.7.2
nim 1.nim 3300ms 230ms 1.9MB 3287ms 0ms nim 1.6.6
nim 1.nim 3433ms 1.4ms 1.8MB 3420ms 0ms nim/clang 1.6.6

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
julia 2-m.jl 612ms 0.6ms 196.9MB 857ms 127ms julia 1.7.2
julia 3-m.jl 838ms 2.5ms 210.4MB 1197ms 130ms julia 1.7.2
nim 1.nim 861ms 0.9ms 0.9MB 850ms 0ms nim/clang 1.6.6
nim 1.nim 862ms 1.5ms 0.9MB 850ms 0ms nim 1.6.6

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
nim 1.nim 210ms 15ms 1.0MB 200ms 0ms nim/clang 1.6.6
nim 1.nim 218ms 0.5ms 0.9MB 207ms 0ms nim 1.6.6
julia 2.jl 439ms 6.7ms 196.5MB 510ms 137ms julia 1.7.2
julia 3.jl 542ms 1.0ms 209.8MB 660ms 123ms julia 1.7.2