Skip to content

Commit 1cdadf4

Browse files
authored
bpo-37759: Show output from var_access_benchmark (GH-17040)
1 parent d0e0f5b commit 1cdadf4

File tree

1 file changed

+52
-3
lines changed

1 file changed

+52
-3
lines changed

Doc/whatsnew/3.8.rst

+52-3
Original file line numberDiff line numberDiff line change
@@ -2152,6 +2152,55 @@ CPython bytecode changes
21522152
Demos and Tools
21532153
---------------
21542154

2155-
* Added a benchmark script for timing various ways to access variables:
2156-
``Tools/scripts/var_access_benchmark.py``.
2157-
(Contributed by Raymond Hettinger in :issue:`35884`.)
2155+
Added a benchmark script for timing various ways to access variables:
2156+
``Tools/scripts/var_access_benchmark.py``.
2157+
(Contributed by Raymond Hettinger in :issue:`35884`.)
2158+
2159+
Here's a summary of performance improvements since Python 3.3:
2160+
2161+
.. code-block:: none
2162+
2163+
Python version 3.3 3.4 3.5 3.6 3.7 3.8
2164+
-------------- --- --- --- --- --- ---
2165+
2166+
Variable and attribute read access:
2167+
read_local 4.0 7.1 7.1 5.4 5.1 3.9
2168+
read_nonlocal 5.3 7.1 8.1 5.8 5.4 4.4
2169+
read_global 13.3 15.5 19.0 14.3 13.6 7.6
2170+
read_builtin 20.0 21.1 21.6 18.5 19.0 7.5
2171+
read_classvar_from_class 20.5 25.6 26.5 20.7 19.5 18.4
2172+
read_classvar_from_instance 18.5 22.8 23.5 18.8 17.1 16.4
2173+
read_instancevar 26.8 32.4 33.1 28.0 26.3 25.4
2174+
read_instancevar_slots 23.7 27.8 31.3 20.8 20.8 20.2
2175+
read_namedtuple 68.5 73.8 57.5 45.0 46.8 18.4
2176+
read_boundmethod 29.8 37.6 37.9 29.6 26.9 27.7
2177+
2178+
Variable and attribute write access:
2179+
write_local 4.6 8.7 9.3 5.5 5.3 4.3
2180+
write_nonlocal 7.3 10.5 11.1 5.6 5.5 4.7
2181+
write_global 15.9 19.7 21.2 18.0 18.0 15.8
2182+
write_classvar 81.9 92.9 96.0 104.6 102.1 39.2
2183+
write_instancevar 36.4 44.6 45.8 40.0 38.9 35.5
2184+
write_instancevar_slots 28.7 35.6 36.1 27.3 26.6 25.7
2185+
2186+
Data structure read access:
2187+
read_list 19.2 24.2 24.5 20.8 20.8 19.0
2188+
read_deque 19.9 24.7 25.5 20.2 20.6 19.8
2189+
read_dict 19.7 24.3 25.7 22.3 23.0 21.0
2190+
read_strdict 17.9 22.6 24.3 19.5 21.2 18.9
2191+
2192+
Data structure write access:
2193+
write_list 21.2 27.1 28.5 22.5 21.6 20.0
2194+
write_deque 23.8 28.7 30.1 22.7 21.8 23.5
2195+
write_dict 25.9 31.4 33.3 29.3 29.2 24.7
2196+
write_strdict 22.9 28.4 29.9 27.5 25.2 23.1
2197+
2198+
Stack (or queue) operations:
2199+
list_append_pop 144.2 93.4 112.7 75.4 74.2 50.8
2200+
deque_append_pop 30.4 43.5 57.0 49.4 49.2 42.5
2201+
deque_append_popleft 30.8 43.7 57.3 49.7 49.7 42.8
2202+
2203+
Timing loop:
2204+
loop_overhead 0.3 0.5 0.6 0.4 0.3 0.3
2205+
2206+
(Measured from the macOS 64-bit builds found at python.org)

0 commit comments

Comments
 (0)