Current benchmark data was generated on Tue Apr 01 2025, full log can be found HERE
CONTRIBUTIONS are WELCOME!
* -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.)
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 1.cs | 948ms | 4.4ms | 196.3MB | 950ms | 160ms | dotnet 9.0.202 |
csharp | 1.cs | 1012ms | 10ms | 166.5MB | 1010ms | 130ms | dotnet/aot 9.0.202 |
haxe | 1.hx | 1322ms | 17ms | 143.9MB | 1503ms | 73ms | haxe/cpp 4.3.6 |
csharp | 1.cs | 1761ms | 69ms | 101.3MB | 1963ms | 233ms | mono 6.12.0 |
haxe | 2.hx | 4401ms | 35ms | 495.1MB | 4920ms | 270ms | haxe/cpp 4.3.6 |
haxe | 1.hx | timeout | 0.0ms | 48.6MB | 5667ms | 400ms | haxe/hl/c 4.3.6 |
haxe | 2.hx | timeout | 0.0ms | 83.2MB | 5040ms | 660ms | haxe/hl/c 4.3.6 |
haxe | 1.hx | timeout | 0.0ms | 50.6MB | 7873ms | 437ms | haxe/hl/jit 1.15.0 |
haxe | 2.hx | timeout | 0.0ms | 130.9MB | 7293ms | 790ms | haxe/hl/jit 1.15.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
haxe | 1.hx | 90ms | 1.5ms | 25.6MB | 80ms | 10ms | haxe/cpp 4.3.6 |
csharp | 1.cs | 133ms | 8.6ms | 32.6MB | 87ms | 33ms | dotnet/aot 9.0.202 |
csharp | 1.cs | 149ms | 2.7ms | 44.2MB | 127ms | 10ms | mono 6.12.0 |
csharp | 1.cs | 202ms | 7.8ms | 51.2MB | 160ms | 37ms | dotnet 9.0.202 |
haxe | 2.hx | 397ms | 9.3ms | 58.3MB | 420ms | 27ms | haxe/cpp 4.3.6 |
haxe | 1.hx | 644ms | 1.9ms | 8.8MB | 610ms | 50ms | haxe/hl/c 4.3.6 |
haxe | 1.hx | 680ms | 1.9ms | 11.3MB | 743ms | 57ms | haxe/hl/jit 1.15.0 |
haxe | 2.hx | 925ms | 6.4ms | 13.6MB | 817ms | 150ms | haxe/hl/c 4.3.6 |
haxe | 2.hx | 1120ms | 30ms | 25.1MB | 1137ms | 180ms | haxe/hl/jit 1.15.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 5-m.cs | 128ms | 3.9ms | 25.0MB | 347ms | 97ms | dotnet/aot 9.0.202 |
csharp | 5-m.cs | 194ms | 5.8ms | 38.8MB | 470ms | 120ms | dotnet 9.0.202 |
csharp | 5-m.cs | 253ms | 7.3ms | 45.3MB | 683ms | 137ms | mono 6.12.0 |
haxe | 1.hx | 2398ms | 8.9ms | 25.6MB | 2283ms | 227ms | haxe/cpp 4.3.6 |
haxe | 1.hx | timeout | 0.0ms | 3.2MB | 4307ms | 903ms | haxe/hl/c 4.3.6 |
haxe | 1.hx | timeout | 0.0ms | 3.7MB | 4363ms | 870ms | haxe/hl/jit 1.15.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 5-m.cs | 25ms | 0.3ms | 16.0MB | 33ms | 13ms | dotnet/aot 9.0.202 |
csharp | 5-m.cs | 63ms | 3.1ms | 37.1MB | 87ms | 20ms | dotnet 9.0.202 |
csharp | 5-m.cs | 73ms | 2.6ms | 32.0MB | 103ms | 23ms | mono 6.12.0 |
haxe | 1.hx | 256ms | 2.4ms | 25.6MB | 223ms | 27ms | haxe/cpp 4.3.6 |
haxe | 1.hx | 670ms | 2.5ms | 3.4MB | 560ms | 123ms | haxe/hl/c 4.3.6 |
haxe | 1.hx | 679ms | 4.7ms | 3.8MB | 593ms | 103ms | haxe/hl/jit 1.15.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
haxe | 1.hx | 2.0ms | 0.1ms | 2.8MB | 0ms | 0ms | haxe/hl/c 4.3.6 |
haxe | 1.hx | 2.5ms | 0.3ms | 4.4MB | 0ms | 0ms | haxe/cpp 4.3.6 |
haxe | 1.hx | 3.7ms | 0.2ms | 2.8MB | 0ms | 0ms | haxe/hl/jit 1.15.0 |
csharp | 1.cs | 10.0ms | 3.3ms | 9.4MB | 0ms | 0ms | dotnet/aot 9.0.202 |
csharp | 1.cs | 31ms | 0.8ms | 21.3MB | 20ms | 0ms | mono 6.12.0 |
csharp | 1.cs | 36ms | 0.4ms | 26.3MB | 20ms | 6ms | dotnet 9.0.202 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 2.cs | 96ms | 1.4ms | 9.9MB | 80ms | 0ms | dotnet/aot 9.0.202 |
haxe | 1.hx | 136ms | 4.1ms | 20.4MB | 120ms | 3ms | haxe/cpp 4.3.6 |
haxe | 1.hx | 142ms | 11ms | 3.1MB | 137ms | 0ms | haxe/hl/c 4.3.6 |
csharp | 2.cs | 151ms | 1.3ms | 21.1MB | 137ms | 0ms | mono 6.12.0 |
haxe | 1.hx | 157ms | 2.5ms | 3.8MB | 147ms | 0ms | haxe/hl/jit 1.15.0 |
csharp | 2.cs | 252ms | 3.5ms | 29.5MB | 237ms | 10ms | dotnet 9.0.202 |
csharp | 1.cs | 1047ms | 8.8ms | 13.1MB | 1030ms | 3ms | dotnet/aot 9.0.202 |
csharp | 1.cs | 1338ms | 47ms | 32.4MB | 1330ms | 10ms | dotnet 9.0.202 |
csharp | 1.cs | 3356ms | 34ms | 45.5MB | 3303ms | 40ms | mono 6.12.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 2.cs | 273ms | 2.6ms | 9.6MB | 260ms | 0ms | dotnet/aot 9.0.202 |
csharp | 2.cs | 361ms | 2.6ms | 22.6MB | 350ms | 0ms | mono 6.12.0 |
haxe | 1.hx | 376ms | 2.1ms | 25.5MB | 360ms | 3ms | haxe/cpp 4.3.6 |
haxe | 1.hx | 396ms | 1.2ms | 3.0MB | 383ms | 0ms | haxe/hl/c 4.3.6 |
csharp | 2.cs | 405ms | 5.7ms | 29.4MB | 390ms | 10ms | dotnet 9.0.202 |
haxe | 1.hx | 460ms | 6.3ms | 3.8MB | 450ms | 0ms | haxe/hl/jit 1.15.0 |
csharp | 1.cs | 3129ms | 26ms | 13.1MB | 3100ms | 13ms | dotnet/aot 9.0.202 |
csharp | 1.cs | 3666ms | 77ms | 33.0MB | 3643ms | 20ms | dotnet 9.0.202 |
csharp | 1.cs | timeout | 0.0ms | 45.6MB | 4947ms | 47ms | mono 6.12.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 2.cs | 54ms | 0.1ms | 9.8MB | 40ms | 0ms | dotnet/aot 9.0.202 |
haxe | 1.hx | 63ms | 0.9ms | 12.6MB | 50ms | 0ms | haxe/cpp 4.3.6 |
haxe | 1.hx | 68ms | 0.3ms | 3.0MB | 60ms | 0ms | haxe/hl/c 4.3.6 |
haxe | 1.hx | 81ms | 0.9ms | 3.6MB | 70ms | 0ms | haxe/hl/jit 1.15.0 |
csharp | 2.cs | 94ms | 2.2ms | 22.8MB | 80ms | 0ms | mono 6.12.0 |
csharp | 2.cs | 167ms | 1.7ms | 29.3MB | 147ms | 10ms | dotnet 9.0.202 |
csharp | 1.cs | 1640ms | 13ms | 32.5MB | 1623ms | 10ms | dotnet 9.0.202 |
csharp | 1.cs | 1819ms | 22ms | 12.9MB | 1797ms | 0ms | dotnet/aot 9.0.202 |
csharp | 1.cs | 1822ms | 11ms | 28.8MB | 1810ms | 0ms | mono 6.12.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 2.cs | 566ms | 11ms | 120.7MB | 500ms | 93ms | dotnet/aot 9.0.202 |
csharp | 1.cs | 614ms | 8.4ms | 150.1MB | 553ms | 133ms | dotnet/aot 9.0.202 |
csharp | 2.cs | 668ms | 5.9ms | 137.7MB | 627ms | 87ms | dotnet 9.0.202 |
csharp | 1.cs | 751ms | 3.6ms | 165.4MB | 690ms | 133ms | dotnet 9.0.202 |
haxe | 1.hx | 898ms | 3.0ms | 95.0MB | 997ms | 47ms | haxe/cpp 4.3.6 |
csharp | 1.cs | 1334ms | 44ms | 144.1MB | 1567ms | 170ms | mono 6.12.0 |
haxe | 1.hx | timeout | 0.0ms | 32.8MB | 4963ms | 503ms | haxe/hl/c 4.3.6 |
haxe | 1.hx | timeout | 0.0ms | 55.0MB | 6013ms | 480ms | haxe/hl/jit 1.15.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 2.cs | 137ms | 4.4ms | 58.4MB | 100ms | 40ms | dotnet/aot 9.0.202 |
csharp | 1.cs | 159ms | 9.7ms | 74.8MB | 123ms | 50ms | dotnet/aot 9.0.202 |
haxe | 1.hx | 167ms | 1.1ms | 26.6MB | 167ms | 10ms | haxe/cpp 4.3.6 |
csharp | 2.cs | 256ms | 2.1ms | 74.6MB | 227ms | 37ms | dotnet 9.0.202 |
csharp | 1.cs | 267ms | 5.4ms | 69.4MB | 240ms | 33ms | mono 6.12.0 |
csharp | 1.cs | 281ms | 2.4ms | 91.4MB | 240ms | 70ms | dotnet 9.0.202 |
haxe | 1.hx | 1301ms | 7.8ms | 10.8MB | 1233ms | 140ms | haxe/hl/c 4.3.6 |
haxe | 1.hx | 1456ms | 27ms | 20.3MB | 1483ms | 140ms | haxe/hl/jit 1.15.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 9.cs | 363ms | 4.2ms | 27.6MB | 343ms | 3ms | dotnet 9.0.202 |
csharp | 8.cs | 373ms | 1.9ms | 9.9MB | 360ms | 0ms | dotnet/aot 9.0.202 |
csharp | 8.cs | 421ms | 0.6ms | 27.6MB | 400ms | 10ms | dotnet 9.0.202 |
haxe | 2.hx | 857ms | 6.0ms | 3.1MB | 847ms | 0ms | haxe/hl/c 4.3.6 |
haxe | 1.hx | 1081ms | 9.3ms | 3.0MB | 1070ms | 0ms | haxe/hl/c 4.3.6 |
csharp | 8.cs | 1251ms | 3.3ms | 22.1MB | 1233ms | 0ms | mono 6.12.0 |
haxe | 3.hx | 1404ms | 8.2ms | 25.6MB | 1597ms | 40ms | haxe/cpp 4.3.6 |
haxe | 2.hx | 2407ms | 5.9ms | 3.6MB | 2397ms | 0ms | haxe/hl/jit 1.15.0 |
haxe | 1.hx | 2470ms | 3.4ms | 3.6MB | 2460ms | 0ms | haxe/hl/jit 1.15.0 |
haxe | 1.hx | timeout | 0.0ms | 4.4MB | 4990ms | 0ms | haxe/cpp 4.3.6 |
haxe | 2.hx | timeout | 0.0ms | 4.4MB | 4990ms | 0ms | haxe/cpp 4.3.6 |
haxe | 3.hx | timeout | 0.0ms | 3.3MB | 3940ms | 1557ms | haxe/hl/c 4.3.6 |
haxe | 3.hx | timeout | 0.0ms | 3.8MB | 4090ms | 1307ms | haxe/hl/jit 1.15.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 8.cs | 45ms | 1.4ms | 9.9MB | 30ms | 0ms | dotnet/aot 9.0.202 |
haxe | 2.hx | 90ms | 2.0ms | 3.0MB | 80ms | 0ms | haxe/hl/c 4.3.6 |
csharp | 9.cs | 95ms | 3.9ms | 27.8MB | 73ms | 10ms | dotnet 9.0.202 |
csharp | 8.cs | 95ms | 0.2ms | 27.6MB | 77ms | 10ms | dotnet 9.0.202 |
haxe | 1.hx | 113ms | 3.0ms | 3.0MB | 107ms | 0ms | haxe/hl/c 4.3.6 |
haxe | 3.hx | 153ms | 0.4ms | 25.6MB | 157ms | 10ms | haxe/cpp 4.3.6 |
csharp | 8.cs | 165ms | 1.8ms | 22.4MB | 153ms | 0ms | mono 6.12.0 |
haxe | 2.hx | 246ms | 1.2ms | 3.6MB | 240ms | 0ms | haxe/hl/jit 1.15.0 |
haxe | 1.hx | 253ms | 3.5ms | 3.6MB | 243ms | 0ms | haxe/hl/jit 1.15.0 |
haxe | 3.hx | 671ms | 2.1ms | 3.3MB | 513ms | 213ms | haxe/hl/c 4.3.6 |
haxe | 2.hx | 679ms | 11ms | 4.4MB | 670ms | 0ms | haxe/cpp 4.3.6 |
haxe | 3.hx | 778ms | 14ms | 3.9MB | 653ms | 187ms | haxe/hl/jit 1.15.0 |
haxe | 1.hx | 810ms | 2.1ms | 4.4MB | 800ms | 0ms | haxe/cpp 4.3.6 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 3-m.cs | 1864ms | 3.2ms | 10.6MB | 7257ms | 10ms | dotnet/aot 9.0.202 |
csharp | 3-m.cs | 2008ms | 131ms | 30.1MB | 7223ms | 17ms | dotnet 9.0.202 |
haxe | 1.hx | 3927ms | 1.7ms | 3.4MB | 3917ms | 0ms | haxe/hl/c 4.3.6 |
csharp | 3-m.cs | 4633ms | 30ms | 24.9MB | 17887ms | 23ms | mono 6.12.0 |
haxe | 1.hx | timeout | 0.0ms | 7.0MB | 4990ms | 0ms | haxe/cpp 4.3.6 |
haxe | 1.hx | timeout | 0.0ms | 3.9MB | 4990ms | 0ms | haxe/hl/jit 1.15.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 3-m.cs | 477ms | 1.9ms | 10.3MB | 1807ms | 3ms | dotnet/aot 9.0.202 |
csharp | 3-m.cs | 535ms | 1.5ms | 30.0MB | 1870ms | 17ms | dotnet 9.0.202 |
haxe | 1.hx | 992ms | 1.9ms | 3.1MB | 980ms | 0ms | haxe/hl/c 4.3.6 |
csharp | 3-m.cs | 1312ms | 112ms | 24.4MB | 4640ms | 13ms | mono 6.12.0 |
haxe | 1.hx | 2399ms | 0.8ms | 6.6MB | 2390ms | 0ms | haxe/cpp 4.3.6 |
haxe | 1.hx | timeout | 0.0ms | 3.8MB | 4987ms | 0ms | haxe/hl/jit 1.15.0 |
lang | code | time | stddev | peak-mem mem | time(user) | time(sys) | compiler compiler/runtime |
---|---|---|---|---|---|---|---|
csharp | 3-m.cs | 129ms | 1.2ms | 10.6MB | 447ms | 3ms | dotnet/aot 9.0.202 |
csharp | 3-m.cs | 178ms | 1.4ms | 28.3MB | 507ms | 10ms | dotnet 9.0.202 |
haxe | 1.hx | 255ms | 2.7ms | 3.1MB | 243ms | 0ms | haxe/hl/c 4.3.6 |
csharp | 3-m.cs | 348ms | 2.9ms | 25.6MB | 1167ms | 10ms | mono 6.12.0 |
haxe | 1.hx | 605ms | 0.7ms | 5.3MB | 593ms | 0ms | haxe/cpp 4.3.6 |
haxe | 1.hx | 2312ms | 0.5ms | 3.6MB | 2300ms | 0ms | haxe/hl/jit 1.15.0 |