Chapel VS Python benchmarks

Current benchmark data was generated on Thu May 01 2025, 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.)

binarytrees

Input: 18

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
python 1.py 1163ms 3.7ms 96.4MB 1093ms 57ms pypy 3.10.16
chapel 4.chpl 1953ms 5.8ms 62.4MB 1947ms 0ms chpl 1.31.0
chapel 3.chpl 2034ms 5.7ms 62.3MB 2027ms 0ms chpl 1.31.0
python 1.py timeout 0.0ms 41.0MB 4967ms 20ms cpython 3.13.3
python 1.py timeout 0.0ms 40.6MB 4747ms 240ms pyston 3.8.12

Input: 15

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
python 1.py 94ms 1.4ms 68.9MB 67ms 20ms pypy 3.10.16
chapel 4.chpl 184ms 0.5ms 32.3MB 180ms 0ms chpl 1.31.0
chapel 3.chpl 189ms 2.4ms 32.3MB 183ms 0ms chpl 1.31.0
python 1.py 477ms 5.2ms 11.9MB 453ms 10ms pyston 3.8.12
python 1.py 735ms 1.9ms 12.9MB 720ms 0ms cpython 3.13.3

coro-prime-sieve

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
python 1.py 1189ms 5.0ms 104.1MB 1140ms 33ms pypy 3.10.16
chapel 1-m.chpl 2236ms 75ms 571.9MB 4350ms 80ms chpl 1.31.0
python 1.py 2813ms 42ms 25.2MB 2797ms 7ms cpython 3.13.3
python 1.py timeout 0.0ms 17.3MB 4980ms 7ms pyston 3.8.12

Input: 1000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1-m.chpl 193ms 3.2ms 540.5MB 307ms 50ms chpl 1.31.0
python 1.py 219ms 1.1ms 84.8MB 180ms 20ms pypy 3.10.16
python 1.py 232ms 1.3ms 20.5MB 210ms 0ms cpython 3.13.3
python 1.py 689ms 14ms 16.8MB 670ms 3ms pyston 3.8.12

edigits

Input: 250001

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 74ms 1.0ms 32.5MB 70ms 0ms chpl 1.31.0
python 1.py 254ms 1.8ms 83.3MB 213ms 27ms pypy 3.10.16
python 1.py 358ms 0.5ms 12.7MB 343ms 0ms cpython 3.13.3
python 1.py 2007ms 3.8ms 9.6MB 1993ms 0ms pyston 3.8.12

Input: 100000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 34ms 0.7ms 30.5MB 30ms 0ms chpl 1.31.0
python 1.py 101ms 2.1ms 63.4MB 77ms 13ms pypy 3.10.16
python 1.py 110ms 2.3ms 11.6MB 97ms 0ms cpython 3.13.3
python 1.py 347ms 0.6ms 8.8MB 340ms 0ms pyston 3.8.12

fasta

Input: 2500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 5-m.chpl 107ms 2.2ms 28.4MB 190ms 0ms chpl 1.31.0
python 1.py 1844ms 2.1ms 88.9MB 1803ms 27ms pypy 3.10.16
python 5-m.py 2282ms 26ms 65.6MB 3447ms 880ms pypy 3.10.16
python 5-m.py 2440ms 42ms 12.5MB 3553ms 983ms pyston 3.8.12
python 1.py 3029ms 17ms 8.1MB 3013ms 0ms pyston 3.8.12
python 5-m.py 3360ms 25ms 13.8MB 4480ms 893ms cpython 3.13.3
python 1.py 4658ms 29ms 8.9MB 4647ms 0ms cpython 3.13.3

Input: 250000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 5.chpl 21ms 1.7ms 28.4MB 20ms 0ms chpl 1.31.0
python 1.py 248ms 3.6ms 63.3MB 217ms 13ms pypy 3.10.16
python 5-m.py 310ms 2.9ms 12.5MB 413ms 133ms pyston 3.8.12
python 1.py 316ms 5.2ms 8.1MB 303ms 0ms pyston 3.8.12
python 5-m.py 405ms 7.8ms 13.9MB 507ms 127ms cpython 3.13.3
python 5-m.py 437ms 3.3ms 65.4MB 743ms 283ms pypy 3.10.16
python 1.py 475ms 3.8ms 8.8MB 463ms 0ms cpython 3.13.3

helloworld

Input: QwQ

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 11ms 0.5ms 28.8MB 0ms 0ms chpl 1.31.0
python 1.py 12ms 0.6ms 7.6MB 0ms 0ms pyston 3.8.12
python 1.py 14ms 1.0ms 8.6MB 10ms 0ms cpython 3.13.3
python 1.py 29ms 1.3ms 51.6MB 10ms 10ms pypy 3.10.16

knucleotide

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3-m.chpl 751ms 2.2ms 85.0MB 1420ms 10ms chpl 1.31.0
python 3-m.py 2338ms 1.4ms 136.4MB 7957ms 330ms pypy 3.10.16
python 3-m.py 3049ms 13ms 34.1MB 11583ms 117ms pyston 3.8.12
python 3.py timeout 0.0ms 35.9MB 90ms 20ms cpython 3.13.3

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3-m.chpl 116ms 1.0ms 87.0MB 200ms 7ms chpl 1.31.0
python 3-m.py 378ms 4.0ms 75.7MB 953ms 153ms pypy 3.10.16
python 3-m.py 396ms 3.0ms 14.3MB 1300ms 67ms pyston 3.8.12
python 3-m.py 666ms 1.7ms 15.2MB 2340ms 70ms cpython 3.13.3

nbody

Input: 5000000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 324ms 3.1ms 28.8MB 320ms 0ms chpl 1.31.0
python 2.py 1359ms 3.9ms 58.1MB 1333ms 10ms pypy 3.10.16
python 1.py 2652ms 15ms 57.1MB 2627ms 13ms pypy 3.10.16
python 1.py timeout 0.0ms 8.8MB 4990ms 0ms cpython 3.13.3
python 2.py timeout 0.0ms 8.9MB 4990ms 0ms cpython 3.13.3
python 1.py timeout 0.0ms 8.3MB 4990ms 0ms pyston 3.8.12
python 2.py timeout 0.0ms 8.1MB 4990ms 0ms pyston 3.8.12

Input: 500000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 45ms 1.4ms 28.8MB 40ms 0ms chpl 1.31.0
python 2.py 180ms 3.6ms 57.9MB 153ms 10ms pypy 3.10.16
python 1.py 303ms 3.1ms 57.2MB 280ms 10ms pypy 3.10.16
python 1.py 926ms 7.5ms 8.3MB 910ms 0ms pyston 3.8.12
python 2.py 1300ms 5.2ms 8.3MB 1293ms 0ms pyston 3.8.12
python 1.py 2952ms 2.0ms 8.9MB 2940ms 0ms cpython 3.13.3
python 2.py 3262ms 188ms 8.9MB 3250ms 0ms cpython 3.13.3

pidigits

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 448ms 1.7ms 30.4MB 440ms 0ms chpl 1.31.0
python 4.py 1915ms 12ms 8.9MB 1873ms 27ms pyston 3.8.12
python 4.py 1986ms 7.7ms 9.4MB 1933ms 40ms cpython 3.13.3
python 4.py 2182ms 4.7ms 89.6MB 2143ms 27ms pypy 3.10.16

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 2.chpl 114ms 1.1ms 30.3MB 110ms 0ms chpl 1.31.0
python 4.py 451ms 2.1ms 8.6MB 440ms 0ms pyston 3.8.12
python 4.py 470ms 1.0ms 9.1MB 460ms 0ms cpython 3.13.3
python 4.py 550ms 2.6ms 83.9MB 520ms 20ms pypy 3.10.16

regex-redux

Input: 2500000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3.chpl 1396ms 9.5ms 220.2MB 1350ms 40ms chpl 1.31.0
python 1.py 2242ms 6.5ms 243.1MB 2183ms 50ms pypy 3.10.16
python 1.py 4755ms 17ms 226.2MB 4557ms 183ms pyston 3.8.12
python 1.py timeout 0.0ms 149.3MB 4917ms 67ms cpython 3.13.3

Input: 250000_in

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 3.chpl 162ms 3.8ms 48.9MB 140ms 17ms chpl 1.31.0
python 1.py 326ms 0.8ms 86.5MB 287ms 23ms pypy 3.10.16
python 1.py 500ms 7.3ms 30.3MB 470ms 20ms pyston 3.8.12
python 1.py 603ms 7.0ms 30.0MB 573ms 13ms cpython 3.13.3

secp256k1

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 1187ms 11ms 29.1MB 1183ms 0ms chpl 1.31.0
python 1.py 3153ms 7.0ms 8.3MB 3143ms 0ms pyston 3.8.12
python 1.py 3535ms 16ms 74.4MB 3503ms 20ms pypy 3.10.16
python 1.py 3806ms 27ms 8.8MB 3797ms 0ms cpython 3.13.3

Input: 500

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1.chpl 307ms 3.0ms 29.0MB 303ms 0ms chpl 1.31.0
python 1.py 802ms 6.6ms 8.3MB 793ms 0ms pyston 3.8.12
python 1.py 961ms 3.4ms 8.8MB 947ms 0ms cpython 3.13.3
python 1.py 988ms 8.0ms 67.4MB 957ms 20ms pypy 3.10.16

spectral-norm

Input: 8000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1-m.chpl 1928ms 23ms 28.9MB 3827ms 0ms chpl 1.31.0
chapel 1.chpl 3719ms 13ms 28.8MB 3713ms 0ms chpl 1.31.0
python 8.py timeout 0.0ms 14.9MB 40ms 7ms cpython 3.13.3
python 8.py timeout 0.0ms 95.8MB 763ms 77ms pypy 3.10.16
python 8.py timeout 0.0ms 14.1MB 30ms 10ms pyston 3.8.12

Input: 4000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1-m.chpl 492ms 2.8ms 28.8MB 960ms 0ms chpl 1.31.0
chapel 1.chpl 944ms 3.9ms 28.8MB 937ms 0ms chpl 1.31.0
python 8.py timeout 0.0ms 14.5MB 43ms 10ms cpython 3.13.3
python 8.py timeout 0.0ms 96.4MB 1267ms 177ms pypy 3.10.16
python 8.py timeout 0.0ms 13.7MB 53ms 17ms pyston 3.8.12

Input: 2000

lang code time stddev peak-mem mem time(user) time(sys) compiler compiler/runtime
chapel 1-m.chpl 134ms 1.5ms 28.9MB 247ms 0ms chpl 1.31.0
chapel 1.chpl 247ms 2.2ms 28.8MB 240ms 0ms chpl 1.31.0
python 8-m.py 1935ms 16ms 93.6MB 6317ms 250ms pypy 3.10.16
python 8.py timeout 0.0ms 14.3MB 83ms 17ms cpython 3.13.3
python 8.py timeout 0.0ms 13.1MB 137ms 30ms pyston 3.8.12