Crystal VS C# benchmarks

Current benchmark data was generated on Mon Oct 03 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
csharp 1.cs 1356ms 24ms 392.1MB 1253ms 170ms dotnet 6.0.401
crystal 1.cr 1532ms 4.2ms 64.5MB 1837ms 13ms crystal 1.5.1
csharp 1.cs 2170ms 29ms 100.2MB 2493ms 153ms mono 6.12.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 132ms 0.9ms 11.1MB 133ms 3ms crystal 1.5.1
csharp 1.cs 153ms 1.8ms 44.8MB 127ms 7ms mono 6.12.0
csharp 1.cs 188ms 2.9ms 89.2MB 127ms 33ms dotnet 6.0.401

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 1933ms 16ms 20.5MB 1897ms 23ms crystal 1.5.1
csharp 1-m.cs 4272ms 154ms 104.3MB 7873ms 80ms dotnet 6.0.401

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 108ms 3.8ms 9.3MB 97ms 0ms crystal 1.5.1
csharp 1-m.cs 408ms 26ms 82.3MB 623ms 43ms dotnet 6.0.401

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 83ms 1.3ms 7.4MB 73ms 0ms crystal 1.5.1
csharp 1.cs timeout 0.0ms 0.0MB 0ms 0ms dotnet 6.0.401

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 31ms 1.0ms 5.2MB 20ms 0ms crystal 1.5.1
csharp 1.cs 1107ms 3.4ms 47.8MB 1070ms 7ms dotnet 6.0.401

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 3968ms 1.9ms 4.9MB 3953ms 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 1.9ms 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
csharp 5-m.cs 404ms 16ms 83.6MB 610ms 107ms dotnet 6.0.401
csharp 5-m.cs 504ms 35ms 85.0MB 833ms 113ms mono 6.12.0
crystal 2.cr 860ms 0.8ms 3.6MB 753ms 93ms crystal 1.5.1
crystal 1.cr 1071ms 23ms 14.7MB 917ms 137ms crystal 1.5.1

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
csharp 5.cs 85ms 4.3ms 36.8MB 103ms 20ms mono 6.12.0
crystal 2.cr 91ms 2.6ms 3.6MB 67ms 7ms crystal 1.5.1
csharp 5.cs 97ms 5.2ms 39.7MB 87ms 17ms dotnet 6.0.401
crystal 1.cr 110ms 0.6ms 6.4MB 87ms 10ms crystal 1.5.1

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 3.0ms 0.8ms 3.1MB 0ms 0ms crystal 1.5.1
csharp 1.cs 19ms 0.8ms 24.3MB 10ms 0ms mono 6.12.0
csharp 1.cs 50ms 7.0ms 27.1MB 18ms 6ms dotnet 6.0.401

http-server

Input: 3000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
csharp 2-http2.cs 642ms 12ms 122.7MB 720ms 90ms dotnet 6.0.401
csharp 2-http3.cs 787ms 27ms 271.8MB 843ms 243ms dotnet 7.0.100-rc.1.22431.12
csharp 2.cs 825ms 29ms 146.2MB 797ms 373ms dotnet 6.0.401
csharp 1-m.cs 878ms 52ms 165.1MB 893ms 437ms dotnet 6.0.401
crystal 1.cr 3452ms 67ms 120.4MB 307ms 273ms crystal 1.5.1

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
csharp 2.cs 442ms 10ms 76.9MB 370ms 103ms dotnet 6.0.401
csharp 1.cs 474ms 5.4ms 83.9MB 467ms 100ms dotnet 6.0.401
csharp 2-http3.cs 499ms 7.8ms 188.8MB 413ms 123ms dotnet 7.0.100-rc.1.22431.12
csharp 2-http2.cs 510ms 12ms 78.4MB 520ms 40ms dotnet 6.0.401
crystal 1.cr 1170ms 104ms 35.0MB 43ms 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.1ms 3.1MB 50ms 0ms crystal 1.5.1
crystal 1.cr 108ms 3.9ms 3.1MB 100ms 0ms crystal 1.5.1
csharp 2.cs 186ms 2.6ms 25.5MB 167ms 0ms mono 6.12.0
csharp 2.cs 206ms 5.1ms 28.1MB 170ms 0ms dotnet 6.0.401
csharp 1.cs 1695ms 39ms 88.7MB 1610ms 33ms dotnet 6.0.401
csharp 1.cs 3023ms 16ms 49.6MB 2993ms 20ms mono 6.12.0

Input: 1000 3000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 174ms 1.0ms 3.1MB 163ms 0ms crystal 1.5.1
crystal 1.cr 312ms 1.1ms 5.0MB 300ms 0ms crystal 1.5.1
csharp 2.cs 462ms 9.8ms 28.4MB 440ms 0ms dotnet 6.0.401
csharp 2.cs 506ms 4.4ms 27.5MB 493ms 0ms mono 6.12.0
csharp 1.cs 4631ms 6.8ms 91.1MB 4590ms 27ms dotnet 6.0.401
csharp 1.cs timeout 0.0ms 0.0MB 0ms 0ms mono 6.12.0

Input: 100 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 0-unsafe.cr 30ms 0.9ms 3.1MB 20ms 0ms crystal 1.5.1
crystal 1.cr 55ms 0.8ms 3.1MB 47ms 0ms crystal 1.5.1
csharp 2.cs 106ms 1.7ms 26.0MB 90ms 3ms mono 6.12.0
csharp 2.cs 134ms 1.6ms 30.0MB 97ms 3ms dotnet 6.0.401
csharp 1.cs 3184ms 4.2ms 77.1MB 3137ms 30ms dotnet 6.0.401
csharp 1.cs 3186ms 0.7ms 30.6MB 3167ms 3ms mono 6.12.0

mandelbrot

Input: 5000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
csharp 2.cs 755ms 19ms 94.3MB 680ms 30ms dotnet 6.0.401
crystal 1.cr 995ms 1.1ms 7.5MB 980ms 0ms crystal 1.5.1
csharp 1.cs 3770ms 131ms 34.4MB 3740ms 0ms dotnet 6.0.401
csharp 3.cs 4339ms 9.3ms 36.3MB 4300ms 3ms dotnet 6.0.401
csharp 1.cs timeout 0.0ms 0.0MB 0ms 0ms mono 6.12.0

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 46ms 0.8ms 6.5MB 40ms 0ms crystal 1.5.1
csharp 2.cs 108ms 1.1ms 36.8MB 60ms 7ms dotnet 6.0.401
csharp 3.cs 251ms 0.8ms 33.2MB 217ms 3ms dotnet 6.0.401
csharp 1.cs 289ms 8.3ms 33.4MB 267ms 3ms dotnet 6.0.401
csharp 1.cs 832ms 3.6ms 25.0MB 820ms 0ms mono 6.12.0

merkletrees

Input: 17

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
csharp 2.cs 914ms 7.1ms 378.8MB 773ms 170ms dotnet 6.0.401
csharp 1.cs 919ms 7.8ms 392.6MB 787ms 170ms dotnet 6.0.401
crystal 1.cr 1058ms 30ms 66.1MB 1223ms 13ms crystal 1.5.1
csharp 1.cs 1663ms 12ms 141.4MB 2043ms 107ms mono 6.12.0

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 202ms 6.2ms 17.5MB 213ms 7ms crystal 1.5.1
csharp 2.cs 259ms 4.0ms 92.3MB 203ms 30ms dotnet 6.0.401
csharp 1.cs 293ms 7.5ms 185.8MB 200ms 70ms dotnet 6.0.401
csharp 1.cs 306ms 3.4ms 72.6MB 290ms 23ms mono 6.12.0

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
csharp 9.cs 403ms 4.5ms 29.4MB 370ms 0ms dotnet 6.0.401
crystal 1.cr 509ms 0.5ms 4.9MB 500ms 0ms crystal 1.5.1
csharp 8.cs 535ms 3.0ms 29.4MB 503ms 0ms dotnet 6.0.401
crystal 2.cr 541ms 1.0ms 3.0MB 530ms 0ms crystal 1.5.1
csharp 8.cs 1111ms 5.5ms 26.4MB 1093ms 0ms mono 6.12.0

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 55ms 0.9ms 3.1MB 47ms 0ms crystal 1.5.1
crystal 2.cr 60ms 2.6ms 2.9MB 50ms 0ms crystal 1.5.1
csharp 9.cs 87ms 3.3ms 27.5MB 60ms 0ms dotnet 6.0.401
csharp 8.cs 103ms 6.9ms 29.3MB 73ms 3ms dotnet 6.0.401
csharp 8.cs 132ms 0.5ms 23.0MB 120ms 0ms mono 6.12.0

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 468ms 0.8ms 8.0MB 457ms 0ms crystal 1.5.1
crystal 1.cr 726ms 51ms 44.8MB 703ms 3ms crystal 1.5.1
csharp 1.cs 734ms 4.5ms 88.1MB 690ms 17ms dotnet 6.0.401
csharp 1.cs 793ms 34ms 82.8MB 763ms 17ms mono 6.12.0
csharp 2.cs 996ms 4.1ms 36.2MB 957ms 10ms dotnet 6.0.401
csharp 2.cs 2434ms 0.4ms 32.4MB 2417ms 3ms mono 6.12.0

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 2.cr 109ms 0.9ms 6.4MB 90ms 0ms crystal 1.5.1
crystal 1.cr 151ms 0.5ms 14.9MB 140ms 0ms crystal 1.5.1
csharp 1.cs 181ms 1.9ms 46.0MB 147ms 10ms dotnet 6.0.401
csharp 1.cs 185ms 2.0ms 40.6MB 167ms 3ms mono 6.12.0
csharp 2.cs 278ms 1.1ms 29.8MB 250ms 3ms dotnet 6.0.401
csharp 2.cs 604ms 0.6ms 27.7MB 583ms 7ms mono 6.12.0

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 2755ms 38ms 6.8MB 3000ms 277ms crystal 1.5.1
csharp 1.cs timeout 0.0ms 0.0MB 0ms 0ms dotnet 6.0.401

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 639ms 4.2ms 7.2MB 660ms 73ms crystal 1.5.1
csharp 1.cs 1271ms 5.4ms 96.5MB 1257ms 37ms dotnet 6.0.401

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 2465ms 3.9ms 195.7MB 2400ms 50ms crystal 1.5.1
csharp 5.cs 3119ms 121ms 618.6MB 2993ms 207ms dotnet 7.0.100-rc.1.22431.12
csharp 5.cs 4149ms 49ms 527.8MB 4090ms 197ms dotnet 6.0.401

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
crystal 1.cr 254ms 1.5ms 22.9MB 233ms 3ms crystal 1.5.1
csharp 5.cs 456ms 3.6ms 179.6MB 390ms 57ms dotnet 7.0.100-rc.1.22431.12
csharp 5.cs 542ms 4.3ms 90.5MB 493ms 27ms dotnet 6.0.401

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
csharp 3-m.cs 3138ms 699ms 32.7MB 5223ms 17ms dotnet 6.0.401
crystal 1.cr timeout 0.0ms 0.0MB 0ms 0ms crystal 1.5.1
csharp 3.cs timeout 0.0ms 0.0MB 0ms 0ms mono 6.12.0

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
csharp 3-m.cs 721ms 1.6ms 30.6MB 1313ms 10ms dotnet 6.0.401
crystal 1.cr 1510ms 2.7ms 5.9MB 1497ms 0ms crystal 1.5.1
csharp 3-m.cs 3184ms 138ms 29.2MB 6040ms 3ms mono 6.12.0

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
csharp 3-m.cs 232ms 2.2ms 30.0MB 357ms 7ms dotnet 6.0.401
crystal 1.cr 381ms 0.4ms 5.6MB 370ms 0ms crystal 1.5.1
csharp 3-m.cs 800ms 2.0ms 27.8MB 1523ms 0ms mono 6.12.0