Python 3.11 Benchmarks Beta

Python 3.11 (beta) benchmarks by Michael Larabel for a future article against Pyston and PyPy. More Python 3.11 benchmarks to come on Phoronix.

HTML result view exported from: https://openbenchmarking.org/result/2206071-PTS-PYTHON3176&sor&grr.

Python 3.11 Benchmarks BetaProcessorMotherboardChipsetMemoryDiskGraphicsAudioMonitorNetworkOSKernelDesktopDisplay ServerOpenGLVulkanCompilerFile-SystemScreen ResolutionPython 3.8.13Python 3.9.13Python 3.10.4Python 3.11b1Python 3.11b3Pyston 2.3.3PyPy 3.9-v7.3.9AMD Ryzen 9 5950X 16-Core @ 3.40GHz (16 Cores / 32 Threads)ASUS ROG CROSSHAIR VIII HERO (WI-FI) (4006 BIOS)AMD Starship/Matisse32GB1000GB Sabrent Rocket 4.0 PlusAMD Radeon RX 6800 16GB (2475/1000MHz)AMD Navi 21 HDMI AudioASUS MG28URealtek RTL8125 2.5GbE + Intel I211 + Intel Wi-Fi 6 AX200Ubuntu 22.045.18.0-051800-generic (x86_64)GNOME Shell 42.0X Server + Wayland4.6 Mesa 22.0.1 (LLVM 13.0.1 DRM 3.46)1.2.204GCC 11.2.0ext43840x2160OpenBenchmarking.orgKernel Details- Transparent Huge Pages: madviseCompiler Details- Python 3.8.13, Python 3.9.13, Python 3.10.4, Python 3.11b1: --build=x86_64-linux-gnu --disable-vtable-verify --disable-werror --enable-bootstrap --enable-cet --enable-checking=release --enable-clocale=gnu --enable-default-pie --enable-gnu-unique-object --enable-languages=c,ada,c++,go,brig,d,fortran,objc,obj-c++,m2 --enable-libphobos-checking=release --enable-libstdcxx-debug --enable-libstdcxx-time=yes --enable-link-serialization=2 --enable-multiarch --enable-multilib --enable-nls --enable-objc-gc=auto --enable-offload-targets=nvptx-none=/build/gcc-11-gBFGDP/gcc-11-11.2.0/debian/tmp-nvptx/usr,amdgcn-amdhsa=/build/gcc-11-gBFGDP/gcc-11-11.2.0/debian/tmp-gcn/usr --enable-plugin --enable-shared --enable-threads=posix --host=x86_64-linux-gnu --program-prefix=x86_64-linux-gnu- --target=x86_64-linux-gnu --with-abi=m64 --with-arch-32=i686 --with-build-config=bootstrap-lto-lean --with-default-libstdcxx-abi=new --with-gcc-major-version-only --with-multilib-list=m32,m64,mx32 --with-target-system-zlib=auto --with-tune=generic --without-cuda-driver -v Processor Details- Scaling Governor: acpi-cpufreq schedutil (Boost: Enabled) - CPU Microcode: 0xa201016Python Details- Python 3.8.13: Python 3.8.13- Python 3.9.13: Python 3.9.13- Python 3.10.4: Python 3.10.4- Python 3.11b1: Python 3.11.0b1- Python 3.11b3: Python 3.11.0b3- Pyston 2.3.3: Python 3.8.12 (heads/release_2.3.3:311297b831 Mar 30 2022 10:20:00)[Pyston 2.3.3 GCC 9.4.0]- PyPy 3.9-v7.3.9: Python 3.9.12 (05fbe3aa5b0845e6c37239768aa455451aa5faba Mar 29 2022 08:15:34)[PyPy 7.3.9 with GCC 10.2.1 20210130 (Red Hat 10.2.1-11)] Security Details- itlb_multihit: Not affected + l1tf: Not affected + mds: Not affected + meltdown: Not affected + spec_store_bypass: Mitigation of SSB disabled via prctl + spectre_v1: Mitigation of usercopy/swapgs barriers and __user pointer sanitization + spectre_v2: Mitigation of Retpolines IBPB: conditional IBRS_FW STIBP: always-on RSB filling + srbds: Not affected + tsx_async_abort: Not affected

Python 3.11 Benchmarks Betapyperformance: python_startuppyperformance: raytracepyperformance: gopyperformance: 2to3pyperformance: django_templatepyperformance: json_loadspyperformance: nbodypyperformance: crypto_pyaespyperformance: floatpyperformance: pathlibpyperformance: chaospyperformance: pickle_pure_pythonpyperformance: regex_compilepybench: Total For Average Test TimesPython 3.8.13Python 3.9.13Python 3.10.4Python 3.11b1Python 3.11b3Pyston 2.3.3PyPy 3.9-v7.3.96.3639019524139.220.295.086.588.314.390.73581358276.2939119524338.517.999.686.987.513.890.03511358266.1837017924235.718.8100.184.079.814.287.23501378405.4622210218325.616.967.152.752.112.952.22251017125.5522810618725.916.565.752.354.012.852.92311056915.8316192.315019.31533.645.939.710.230.914751.24085.8816192.415019.315.133.546.039.910.330.914751.6233OpenBenchmarking.org

PyPerformance

Benchmark: python_startup

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: python_startupPython 3.11b1Python 3.11b3Pyston 2.3.3PyPy 3.9-v7.3.9Python 3.10.4Python 3.9.13Python 3.8.13246810SE +/- 0.01, N = 3SE +/- 0.00, N = 3SE +/- 0.01, N = 3SE +/- 0.00, N = 3SE +/- 0.01, N = 3SE +/- 0.01, N = 3SE +/- 0.00, N = 35.465.555.835.886.186.296.36

PyPerformance

Benchmark: raytrace

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: raytracePyston 2.3.3PyPy 3.9-v7.3.9Python 3.11b1Python 3.11b3Python 3.10.4Python 3.8.13Python 3.9.1380160240320400SE +/- 0.33, N = 3SE +/- 0.58, N = 3SE +/- 0.33, N = 3SE +/- 0.00, N = 3SE +/- 0.88, N = 3SE +/- 0.33, N = 3SE +/- 1.53, N = 3161161222228370390391

PyPerformance

Benchmark: go

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: goPyston 2.3.3PyPy 3.9-v7.3.9Python 3.11b1Python 3.11b3Python 3.10.4Python 3.8.13Python 3.9.134080120160200SE +/- 0.06, N = 3SE +/- 0.06, N = 3SE +/- 0.33, N = 3SE +/- 0.33, N = 3SE +/- 0.58, N = 3SE +/- 0.33, N = 3SE +/- 0.58, N = 392.392.4102.0106.0179.0195.0195.0

PyPerformance

Benchmark: 2to3

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: 2to3Pyston 2.3.3PyPy 3.9-v7.3.9Python 3.11b1Python 3.11b3Python 3.8.13Python 3.10.4Python 3.9.1350100150200250SE +/- 0.33, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.33, N = 3SE +/- 0.33, N = 3SE +/- 0.00, N = 3SE +/- 0.88, N = 3150150183187241242243

PyPerformance

Benchmark: django_template

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: django_templatePyston 2.3.3PyPy 3.9-v7.3.9Python 3.11b1Python 3.11b3Python 3.10.4Python 3.9.13Python 3.8.13918273645SE +/- 0.03, N = 3SE +/- 0.03, N = 3SE +/- 0.03, N = 3SE +/- 0.03, N = 3SE +/- 0.13, N = 3SE +/- 0.03, N = 3SE +/- 0.07, N = 319.319.325.625.935.738.539.2

PyPerformance

Benchmark: json_loads

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: json_loadsPyston 2.3.3PyPy 3.9-v7.3.9Python 3.11b3Python 3.11b1Python 3.9.13Python 3.10.4Python 3.8.13510152025SE +/- 0.00, N = 3SE +/- 0.03, N = 3SE +/- 0.03, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.06, N = 3SE +/- 0.03, N = 315.015.116.516.917.918.820.2

PyPerformance

Benchmark: nbody

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: nbodyPyPy 3.9-v7.3.9Pyston 2.3.3Python 3.11b3Python 3.11b1Python 3.8.13Python 3.9.13Python 3.10.420406080100SE +/- 0.12, N = 3SE +/- 0.26, N = 3SE +/- 0.33, N = 3SE +/- 0.29, N = 3SE +/- 0.35, N = 3SE +/- 0.20, N = 3SE +/- 0.49, N = 333.533.665.767.195.099.6100.1

PyPerformance

Benchmark: crypto_pyaes

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: crypto_pyaesPyston 2.3.3PyPy 3.9-v7.3.9Python 3.11b3Python 3.11b1Python 3.10.4Python 3.8.13Python 3.9.1320406080100SE +/- 0.03, N = 3SE +/- 0.03, N = 3SE +/- 0.06, N = 3SE +/- 0.09, N = 3SE +/- 0.15, N = 3SE +/- 0.10, N = 3SE +/- 0.07, N = 345.946.052.352.784.086.586.9

PyPerformance

Benchmark: float

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: floatPyston 2.3.3PyPy 3.9-v7.3.9Python 3.11b1Python 3.11b3Python 3.10.4Python 3.9.13Python 3.8.1320406080100SE +/- 0.12, N = 3SE +/- 0.09, N = 3SE +/- 0.15, N = 3SE +/- 0.09, N = 3SE +/- 0.15, N = 3SE +/- 0.12, N = 3SE +/- 0.03, N = 339.739.952.154.079.887.588.3

PyPerformance

Benchmark: pathlib

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: pathlibPyston 2.3.3PyPy 3.9-v7.3.9Python 3.11b3Python 3.11b1Python 3.9.13Python 3.10.4Python 3.8.1348121620SE +/- 0.00, N = 3SE +/- 0.00, N = 3SE +/- 0.03, N = 3SE +/- 0.03, N = 3SE +/- 0.03, N = 3SE +/- 0.00, N = 3SE +/- 0.00, N = 310.210.312.812.913.814.214.3

PyPerformance

Benchmark: chaos

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: chaosPyston 2.3.3PyPy 3.9-v7.3.9Python 3.11b1Python 3.11b3Python 3.10.4Python 3.9.13Python 3.8.1320406080100SE +/- 0.03, N = 3SE +/- 0.00, N = 3SE +/- 0.20, N = 3SE +/- 0.15, N = 3SE +/- 0.20, N = 3SE +/- 0.03, N = 3SE +/- 0.03, N = 330.930.952.252.987.290.090.7

PyPerformance

Benchmark: pickle_pure_python

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: pickle_pure_pythonPyston 2.3.3PyPy 3.9-v7.3.9Python 3.11b1Python 3.11b3Python 3.10.4Python 3.9.13Python 3.8.1380160240320400SE +/- 0.00, N = 3SE +/- 0.33, N = 3SE +/- 0.00, N = 3SE +/- 0.33, N = 3SE +/- 0.88, N = 3SE +/- 0.33, N = 3SE +/- 0.58, N = 3147147225231350351358

PyPerformance

Benchmark: regex_compile

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyPerformance 1.0.0Benchmark: regex_compilePyston 2.3.3PyPy 3.9-v7.3.9Python 3.11b1Python 3.11b3Python 3.8.13Python 3.9.13Python 3.10.4306090120150SE +/- 0.07, N = 3SE +/- 0.07, N = 3SE +/- 0.00, N = 3SE +/- 0.33, N = 3SE +/- 0.00, N = 3SE +/- 0.33, N = 3SE +/- 0.33, N = 351.251.6101.0105.0135.0135.0137.0

PyBench

Total For Average Test Times

OpenBenchmarking.orgMilliseconds, Fewer Is BetterPyBench 2018-02-16Total For Average Test TimesPyPy 3.9-v7.3.9Pyston 2.3.3Python 3.11b3Python 3.11b1Python 3.9.13Python 3.8.13Python 3.10.42004006008001000SE +/- 0.00, N = 3SE +/- 3.21, N = 3SE +/- 3.38, N = 3SE +/- 1.76, N = 3SE +/- 3.18, N = 3SE +/- 5.57, N = 3SE +/- 4.63, N = 3233408691712826827840


Phoronix Test Suite v10.8.5