C++ VS Python benchmarks

Current benchmark data was generated on Sat Nov 16 2024, full log can be found HERE

CONTRIBUTIONS are WELCOME!

[x86_64][4 cores] AMD EPYC 7763 64-Core Processor (Model 1)

* -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.)

fannkuch-redux

Input: 11

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 1-im.cpp 403ms 8.3ms 4.5MB 1543ms 0ms g++ 11.4.0
cpp 1-im.cpp 405ms 7.4ms 7.9MB 1547ms 3ms clang++ 14.0.0-1ubuntu1.1

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 1-im.cpp 42ms 1.0ms 5.9MB 123ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 1-im.cpp 44ms 0.9ms 4.5MB 140ms 0ms g++ 11.4.0

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 1.cpp 1.0ms 0.0ms 1.4MB 0ms 0ms g++ 11.4.0
cpp 1.cpp 1.4ms 0.1ms 2.3MB 0ms 0ms clang++ 14.0.0-1ubuntu1.1
python 1.py 11ms 0.9ms 7.6MB 10ms 0ms pyston 3.8.12
python 1.py 14ms 1.1ms 8.5MB 0ms 0ms cpython 3.13.0
python 1.py 29ms 1.0ms 51.0MB 10ms 10ms pypy 3.10.14

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 0-i.cpp 166ms 0.2ms 1.5MB 160ms 0ms g++ 11.4.0
cpp 0-i.cpp 170ms 0.3ms 2.3MB 160ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 1.cpp 313ms 1.4ms 1.9MB 300ms 0ms g++ 11.4.0
cpp 1.cpp 314ms 0.4ms 2.3MB 300ms 0ms clang++ 14.0.0-1ubuntu1.1
python 2.py 1351ms 7.9ms 59.8MB 1323ms 17ms pypy 3.10.14
python 1.py 2634ms 23ms 56.6MB 2610ms 10ms pypy 3.10.14
python 1.py timeout 0.0ms 8.8MB 4987ms 3ms cpython 3.13.0
python 2.py timeout 0.0ms 8.8MB 4990ms 0ms cpython 3.13.0
python 1.py timeout 0.0ms 8.3MB 4987ms 3ms pyston 3.8.12
python 2.py timeout 0.0ms 8.1MB 4987ms 0ms pyston 3.8.12

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 0-i.cpp 18ms 0.1ms 1.5MB 10ms 0ms g++ 11.4.0
cpp 0-i.cpp 19ms 0.1ms 2.3MB 10ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 1.cpp 34ms 0.8ms 1.8MB 23ms 0ms g++ 11.4.0
cpp 1.cpp 34ms 0.5ms 2.3MB 27ms 0ms clang++ 14.0.0-1ubuntu1.1
python 2.py 176ms 1.4ms 57.6MB 147ms 13ms pypy 3.10.14
python 1.py 301ms 4.2ms 56.6MB 273ms 10ms pypy 3.10.14
python 1.py 926ms 8.6ms 8.3MB 910ms 0ms pyston 3.8.12
python 2.py 1297ms 12ms 8.1MB 1280ms 0ms pyston 3.8.12
python 1.py 3025ms 45ms 8.8MB 3007ms 3ms cpython 3.13.0
python 2.py 3179ms 124ms 8.8MB 3167ms 0ms cpython 3.13.0

nsieve

Input: 12

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 1.cpp 484ms 2.1ms 7.3MB 470ms 0ms g++ 11.4.0
cpp 1.cpp 530ms 0.3ms 7.7MB 520ms 0ms clang++ 14.0.0-1ubuntu1.1
python 1.py 2508ms 22ms 369.0MB 2427ms 63ms pypy 3.10.14
python 2.py 2995ms 49ms 632.9MB 2827ms 153ms pyston 3.8.12
python 1.py 4841ms 38ms 320.4MB 4780ms 47ms pyston 3.8.12
python 1.py timeout 0.0ms 321.3MB 4953ms 27ms cpython 3.13.0
python 2.py timeout 0.0ms 633.6MB 4820ms 160ms cpython 3.13.0
python 2.py timeout 0.0ms 959.3MB 4683ms 300ms pypy 3.10.14

Input: 10

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 1.cpp 120ms 2.3ms 3.6MB 110ms 0ms g++ 11.4.0
cpp 1.cpp 132ms 0.8ms 4.0MB 120ms 0ms clang++ 14.0.0-1ubuntu1.1
python 1.py 539ms 11ms 134.6MB 497ms 27ms pypy 3.10.14
python 2.py 720ms 4.3ms 164.2MB 673ms 30ms pyston 3.8.12
python 1.py 1102ms 6.4ms 86.0MB 1077ms 10ms pyston 3.8.12
python 2.py 1394ms 3.2ms 164.9MB 1350ms 27ms cpython 3.13.0
python 2.py 1533ms 15ms 289.7MB 1447ms 70ms pypy 3.10.14
python 1.py 2681ms 12ms 86.9MB 2650ms 10ms cpython 3.13.0

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 8-m.cpp 470ms 3.4ms 5.4MB 1820ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 8-m.cpp 484ms 2.2ms 4.2MB 1877ms 0ms g++ 11.4.0
cpp 6-im.cpp 931ms 22ms 7.4MB 3610ms 10ms clang++ 14.0.0-1ubuntu1.1
cpp 6-im.cpp 932ms 17ms 4.3MB 3617ms 0ms g++ 11.4.0
python 8.py timeout 0.0ms 16.8MB 43ms 10ms cpython 3.13.0
python 8.py timeout 0.0ms 100.4MB 843ms 157ms pypy 3.10.14
python 8.py timeout 0.0ms 18.3MB 67ms 20ms pyston 3.8.12

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 8-m.cpp 125ms 0.5ms 5.4MB 450ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 8-m.cpp 129ms 0.9ms 4.1MB 473ms 0ms g++ 11.4.0
cpp 6-im.cpp 239ms 2.6ms 5.4MB 897ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 6-im.cpp 241ms 2.7ms 4.2MB 917ms 0ms g++ 11.4.0
python 8.py timeout 0.0ms 16.4MB 110ms 20ms cpython 3.13.0
python 8.py timeout 0.0ms 97.6MB 1480ms 487ms pypy 3.10.14
python 8.py timeout 0.0ms 17.5MB 137ms 43ms pyston 3.8.12

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
cpp 8-m.cpp 38ms 0.7ms 7.3MB 107ms 3ms clang++ 14.0.0-1ubuntu1.1
cpp 8-m.cpp 40ms 1.0ms 4.0MB 127ms 0ms g++ 11.4.0
cpp 6-im.cpp 67ms 0.4ms 5.4MB 223ms 0ms clang++ 14.0.0-1ubuntu1.1
cpp 6-im.cpp 69ms 1.4ms 4.0MB 233ms 0ms g++ 11.4.0
python 8-m.py 1978ms 11ms 94.6MB 6323ms 333ms pypy 3.10.14
python 8.py timeout 0.0ms 14.1MB 243ms 43ms cpython 3.13.0
python 8.py timeout 0.0ms 17.2MB 390ms 117ms pyston 3.8.12