Skip to content

Latest commit

 

History

History
3234 lines (3008 loc) · 65.9 KB

bm-20250121-azure-x86_64-brandtbucher-remove_optimizer_api-3.14.0a4+-085e172-pystats-comprehensions-vs-base.md

File metadata and controls

3234 lines (3008 loc) · 65.9 KB

Execution counts

Execution counts for Tier 1 instructions.

The "miss ratio" column shows the percentage of times the instruction executed that it deoptimized. When this happens, the base unspecialized instruction is not counted.

Name Base Count Head Count Change
ENTER_EXECUTOR 21,317,200 21,317,200 0.0%
LOAD_FAST 15,244,980 15,244,980 0.0%
POP_TOP 15,237,960 15,237,960 0.0%
RESUME_CHECK 14,748,240 14,748,240 0.0%
INTERPRETER_EXIT 14,745,780 14,745,780 0.0%
YIELD_VALUE 14,254,440 14,254,440 0.0%
FOR_ITER_LIST 8,857,200 8,857,200 0.0%
STORE_FAST_LOAD_FAST 8,855,220 8,855,220 0.0%
GET_ITER 8,851,980 8,851,980 0.0%
POP_JUMP_IF_TRUE 8,847,480 8,847,480 0.0%
TO_BOOL_NONE 8,847,360 8,847,360 0.0%
RETURN_VALUE 7,868,040 7,868,040 0.0%
POP_JUMP_IF_FALSE 6,389,820 6,389,820 0.0%
LIST_APPEND 5,906,100 5,906,100 0.0%
TO_BOOL_BOOL 5,898,300 5,898,300 0.0%
STORE_FAST 499,800 499,800 0.0%
LOAD_ATTR_INSTANCE_VALUE 499,620 499,620 0.0%
LOAD_CONST_IMMORTAL 496,620 496,620 0.0%
LOAD_SMALL_INT 494,700 494,700 0.0%
PUSH_NULL 493,860 493,860 0.0%
EXIT_INIT_CHECK 492,960 492,960 0.0%
LOAD_GLOBAL_BUILTIN 491,700 491,700 0.0%
CALL_LEN 491,580 491,580 0.0%
COMPARE_OP_INT 491,580 491,580 0.0%
NOT_TAKEN 81,880 81,880 0.0%
LOAD_FAST_LOAD_FAST 13,260 13,260 0.0%
JUMP_BACKWARD 10,980
STORE_ATTR_INSTANCE_VALUE 8,640 8,640 0.0%
FOR_ITER_TUPLE 3,240 3,240 0.0%
POP_ITER 3,060 3,060 0.0%
SWAP 2,880 2,880 0.0%
BINARY_OP_ADD_INT 2,880 2,880 0.0%
LOAD_GLOBAL_MODULE 2,040 2,040 0.0%
BUILD_LIST 1,560 1,560 0.0%
LOAD_METHOD_NO_DICT 1,560 1,560 0.0%
BINARY_SUBSCR 1,500 1,500 0.0%
CALL_ALLOC_AND_ENTER_INIT 1,500 1,500 0.0%
BUILD_SLICE 1,440 1,440 0.0%
LOAD_FAST_AND_CLEAR 1,440 1,440 0.0%
CALL_LIST_APPEND 1,440 1,440 0.0%
LOAD_CONST_MORTAL 1,380 1,380 0.0%
LOAD_DEREF 660 660 0.0%
LOAD_ATTR_CLASS_WITH_METACLASS_CHECK 540 540 0.0%
FOR_ITER_GEN 540 540 0.0%
CALL_PY_EXACT_ARGS 480 480 0.0%
BINARY_SUBSCR_DICT 360 360 0.0%
CALL 320 320 0.0%
BUILD_TUPLE 300 300 0.0%
CALL_NON_PY_GENERAL 300 300 0.0%
FOR_ITER_RANGE 300 300 0.0%
MAKE_FUNCTION 240 240 0.0%
COPY_FREE_VARS 240 240 0.0%
MAKE_CELL 240 240 0.0%
SET_FUNCTION_ATTRIBUTE 240 240 0.0%
LOAD_ATTR_MODULE 240 240 0.0%
END_FOR 180 180 0.0%
RETURN_GENERATOR 180 180 0.0%
LOAD_GLOBAL 180 180 0.0%
LOAD_METHOD 160 160 0.0%
LOAD_ATTR 140 140 0.0%
CALL_FUNCTION_EX 120 120 0.0%
CALL_BUILTIN_CLASS 120 120 0.0%
LOAD_METHOD_WITH_VALUES 120 120 0.0%
TO_BOOL 100 100 0.0%
NOP 60 60 0.0%
CALL_INTRINSIC_1 60 60 0.0%
FOR_ITER 60 60 0.0%
IS_OP 60 60 0.0%
JUMP_FORWARD 60 60 0.0%
LIST_EXTEND 60 60 0.0%
POP_JUMP_IF_NOT_NONE 60 60 0.0%
STORE_DEREF 60 60 0.0%
STORE_FAST_STORE_FAST 60 60 0.0%
BINARY_OP_SUBTRACT_FLOAT 60 60 0.0%
BINARY_SUBSCR_TUPLE_INT 60 60 0.0%
CALL_METHOD_DESCRIPTOR_NOARGS 60 60 0.0%
CALL_METHOD_DESCRIPTOR_O 60 60 0.0%
CALL_PY_GENERAL 60 60 0.0%
UNPACK_SEQUENCE_TWO_TUPLE 60 60 0.0%
BINARY_OP 20 20 0.0%
COMPARE_OP 20 20 0.0%
UNPACK_SEQUENCE 20 20 0.0%
JUMP_BACKWARD_JIT 10,980

Pair counts

Pair counts for top 100 opcode pairs

Pairs of specialized operations that deoptimize and are then followed by the corresponding unspecialized instruction are not counted as pairs.

Not included in comparative output.

Predecessor/Successor Pairs

Top 5 predecessors and successors of each Tier 1 opcode.

This does not include the unspecialized instructions that occur after a specialized instruction deoptimizes.

Not included in comparative output.

Specialization stats

Specialization stats by family

BINARY_OP

specialization stats for BINARY_OP family
Kind Base Count Base Ratio Head Count Head Ratio Change
hit

Specialized instructions that complete.

2,940 99.3% 2,940 99.3% 0.0%
Success Base Count Base Ratio Head Count Head Ratio Change
Success 20 100.0% 20 100.0% 0.0%
Failure 0 0.0% 0 0.0%

BINARY_SUBSCR

specialization stats for BINARY_SUBSCR family
Kind Base Count Base Ratio Head Count Head Ratio Change
deferred

Lists the number of "deferred" (i.e. not specialized) instructions executed.

1,440 0.0% 1,440 0.0% 0.0%
hit

Specialized instructions that complete.

26,542,500 100.0% 26,542,500 100.0% 0.0%
Success Base Count Base Ratio Head Count Head Ratio Change
Success 20 33.3% 20 33.3% 0.0%
Failure 40 66.7% 40 66.7% 0.0%
Failure kind Base Count Base Ratio Head Count Head Ratio Change
list slice 40 100.0% 40 100.0% 0.0%

CALL

specialization stats for CALL family
Kind Base Count Base Ratio Head Count Head Ratio Change
hit

Specialized instructions that complete.

102,239,820 100.0% 102,239,820 100.0% 0.0%
Success Base Count Base Ratio Head Count Head Ratio Change
Success 320 100.0% 320 100.0% 0.0%
Failure 0 0.0% 0 0.0%

COMPARE_OP

specialization stats for COMPARE_OP family
Kind Base Count Base Ratio Head Count Head Ratio Change
hit

Specialized instructions that complete.

9,338,940 100.0% 9,338,940 100.0% 0.0%
Success Base Count Base Ratio Head Count Head Ratio Change
Success 20 100.0% 20 100.0% 0.0%
Failure 0 0.0% 0 0.0%

FOR_ITER

specialization stats for FOR_ITER family
Kind Base Count Base Ratio Head Count Head Ratio Change
deferred

Lists the number of "deferred" (i.e. not specialized) instructions executed.

60 0.0% 60 0.0% 0.0%
hit

Specialized instructions that complete.

8,861,280 100.0% 8,861,280 100.0% 0.0%

LOAD_ATTR

specialization stats for LOAD_ATTR family
Kind Base Count Base Ratio Head Count Head Ratio Change
hit

Specialized instructions that complete.

177,940,260 100.0% 177,940,260 100.0% 0.0%
miss

Specialized instructions that deopt.

540 0.0% 540 0.0% 0.0%
Success Base Count Base Ratio Head Count Head Ratio Change
Success 140 100.0% 140 100.0% 0.0%
Failure 0 0.0% 0 0.0%

LOAD_GLOBAL

specialization stats for LOAD_GLOBAL family
Kind Base Count Base Ratio Head Count Head Ratio Change
hit

Specialized instructions that complete.

9,341,100 100.0% 9,341,100 100.0% 0.0%
Success Base Count Base Ratio Head Count Head Ratio Change
Success 180 100.0% 180 100.0% 0.0%
Failure 0 0.0% 0 0.0%

LOAD_METHOD

specialization stats for LOAD_METHOD family
Kind Base Count Base Ratio Head Count Head Ratio Change
deferred

Lists the number of "deferred" (i.e. not specialized) instructions executed.

60 37.5% 60 37.5% 0.0%
Success Base Count Base Ratio Head Count Head Ratio Change
Success 80 80.0% 80 80.0% 0.0%
Failure 20 20.0% 20 20.0% 0.0%

STORE_ATTR

specialization stats for STORE_ATTR family
Kind Base Count Base Ratio Head Count Head Ratio Change
hit

Specialized instructions that complete.

1,483,200 100.0% 1,483,200 100.0% 0.0%

TO_BOOL

specialization stats for TO_BOOL family
Kind Base Count Base Ratio Head Count Head Ratio Change
deferred

Lists the number of "deferred" (i.e. not specialized) instructions executed.

60 0.0% 60 0.0% 0.0%
hit

Specialized instructions that complete.

35,389,500 100.0% 35,389,500 100.0% 0.0%
Success Base Count Base Ratio Head Count Head Ratio Change
Success 20 50.0% 20 50.0% 0.0%
Failure 20 50.0% 20 50.0% 0.0%
Failure kind Base Count Base Ratio Head Count Head Ratio Change
sequence 20 100.0% 20 100.0% 0.0%

UNPACK_SEQUENCE

specialization stats for UNPACK_SEQUENCE family
Kind Base Count Base Ratio Head Count Head Ratio Change
hit

Specialized instructions that complete.

60 75.0% 60 75.0% 0.0%
Success Base Count Base Ratio Head Count Head Ratio Change
Success 20 100.0% 20 100.0% 0.0%
Failure 0 0.0% 0 0.0%

Specialization effectiveness

specialization effectiveness

All entries are execution counts. Should add up to the total number of Tier 1 instructions executed.

Instructions Base Count Base Ratio Head Count Head Ratio Change
Specialized hits

Specialized instructions, e.g. LOAD_ATTR_MODULE that complete.

40,847,580 24.0% 40,858,560 24.0% 0.0%
Basic

Instructions that are not and cannot be specialized, e.g. LOAD_FAST.

129,619,700 76.0% 129,608,720 76.0% -0.0%
Not specialized

Instructions that could be specialized but aren't, e.g. LOAD_ATTR, BINARY_SLICE.

2,520 0.0% 2,520 0.0% 0.0%
Specialized misses

Specialized instructions, e.g. LOAD_ATTR_MODULE that deopt.

660 0.0% 660 0.0% 0.0%

Deferred by instruction

Breakdown of deferred (not specialized) instruction counts by family
Name Base Count Base Ratio Head Count Head Ratio Change
BINARY_SUBSCR 1,440 88.9% 1,440 88.9% 0.0%
TO_BOOL 60 3.7% 60 3.7% 0.0%
FOR_ITER 60 3.7% 60 3.7% 0.0%
LOAD_METHOD 60 3.7% 60 3.7% 0.0%
BINARY_SLICE 0 0.0% 0 0.0%
STORE_SLICE 0 0.0% 0 0.0%
CACHE 0 0.0% 0 0.0%
CALL_FUNCTION_EX 0 0.0% 0 0.0%
END_FOR 0 0.0% 0 0.0%
EXIT_INIT_CHECK 0 0.0% 0 0.0%

Misses by instruction

Breakdown of misses (specialized deopts) instruction counts by family
Name Base Count Base Ratio Head Count Head Ratio Change
LOAD_ATTR_CLASS_WITH_METACLASS_CHECK 540 69.2% 540 69.2% 0.0%
RESUME 120 15.4% 120 15.4% 0.0%
RESUME_CHECK 120 15.4% 120 15.4% 0.0%
CACHE 0 0.0% 0 0.0%
CALL_FUNCTION_EX 0 0.0% 0 0.0%
END_FOR 0 0.0% 0 0.0%
EXIT_INIT_CHECK 0 0.0% 0 0.0%
GET_ITER 0 0.0% 0 0.0%
INTERPRETER_EXIT 0 0.0% 0 0.0%
MAKE_FUNCTION 0 0.0% 0 0.0%

Call stats

Inlined calls and frame stats

This shows what fraction of calls to Python functions are inlined (i.e. not having a call at the C level) and for those that are not, where the call comes from. The various categories overlap.

Also includes the count of frame objects created.

Base Count Base Ratio Head Count Head Ratio Change
Calls to PyEval_EvalDefault 14,745,840 32.6% 14,745,840 32.6% 0.0%
Calls to Python functions inlined 30,476,820 67.4% 30,476,820 67.4% 0.0%
Calls via PyEval_EvalFrame (total) 14,745,840 32.6% 14,745,840 32.6% 0.0%
Calls via PyEval_EvalFrame (vector) 240 0.0% 240 0.0% 0.0%
Calls via PyEval_EvalFrame (generator) 14,745,600 32.6% 14,745,600 32.6% 0.0%
Calls via PyEval_EvalFrame (legacy) 0 0.0% 0 0.0%
Calls via PyEval_EvalFrame (function vectorcall) 240 0.0% 240 0.0% 0.0%
Calls via PyEval_EvalFrame (build class) 0 0.0% 0 0.0%
Calls via PyEval_EvalFrame (slot) 0 0.0% 0 0.0%
Calls via PyEval_EvalFrame (function ex) 60 0.0% 60 0.0% 0.0%
Calls via PyEval_EvalFrame (api) 180 0.0% 180 0.0% 0.0%
Calls via PyEval_EvalFrame (method) 0 0.0% 0 0.0%
Frame objects created 0 0.0% 0 0.0%
Frames pushed 30,969,480 68.5% 30,969,480 68.5% 0.0%

Object stats

Allocations, frees and dict materializatons

Below, "allocations" means "allocations that are not from a freelist". Total allocations = "Allocations from freelist" + "Allocations".

"Inline values" is the number of values arrays inlined into objects.

The cache hit/miss numbers are for the MRO cache, split into dunder and other names.

Base Count Base Ratio Head Count Head Ratio Change
Method cache dunder misses 2 0 -100.0%
Method cache collisions 34 26 -23.5%
Method cache misses 40 42 5.0%
Method cache dunder hits 178 180 1.1%
Method cache hits 23,594,220 23,594,218 -0.0%
Frees 51,617,462 51,617,461 -0.0%
Immortal decrefs 392,451,380 30.7% 392,451,381 30.7% 0.0%
Mortal decrefs 675,760,084 52.9% 675,760,083 52.9% -0.0%
Allocations from freelist 21,126,640 33.8% 21,126,640 33.8% 0.0%
Frees to freelist 21,126,540 21,126,540 0.0%
Allocations 41,294,220 66.2% 41,294,220 66.2% 0.0%
Allocations to 512 bytes 40,311,180 64.6% 40,311,180 64.6% 0.0%
Allocations to 4 kbytes 983,040 1.6% 983,040 1.6% 0.0%
Allocations over 4 kbytes 0 0.0% 0 0.0%
Inline values 492,960 492,960 0.0%
Interpreter mortal increfs 46,923,640 4.0% 46,923,640 4.0% 0.0%
Interpreter mortal decrefs 172,271,600 13.5% 172,271,600 13.5% 0.0%
Mortal increfs 741,638,182 63.7% 741,638,182 63.7% 0.0%
Interpreter immortal increfs 41,315,520 3.5% 41,315,520 3.5% 0.0%
Interpreter immortal decrefs 35,906,340 2.8% 35,906,340 2.8% 0.0%
Immortal increfs 335,227,122 28.8% 335,227,122 28.8% 0.0%
Materialize dict (on request) 0 0.0% 0 0.0%
Materialize dict (new key) 0 0.0% 0 0.0%
Materialize dict (too big) 0 0.0% 0 0.0%
Materialize dict (str subclass) 0 0.0% 0 0.0%

GC stats

GC collections and effectiveness

Collected/visits gives some measure of efficiency.

Generation Base Collections Base Objects collected Base Object visits Base Reachable from roots Base Not reachable from roots Head Collections Head Objects collected Head Object visits Head Reachable from roots Head Not reachable from roots
0 0 0 0 0 0 0 0 0 0 0
1 0 0 0 0 0 0 0 0 0 0
2 0 0 0 0 0 0 0 0 0 0

Optimization (Tier 2) stats

statistics about the Tier 2 optimizer
Base Count Base Ratio Head Count Head Ratio Change
Optimization attempts

The number of times a potential trace is identified. Specifically, this occurs in the JUMP BACKWARD instruction when the counter reaches a threshold.

5,180 5,180 0.0%
Traces created

The number of traces that were successfully created.

20 0.4% 20 0.4% 0.0%
Trace stack overflow

A trace is truncated because it would require more than 5 stack frames.

0 0.0% 0 0.0%
Trace stack underflow

A potential trace is abandoned because it pops more frames than it pushes.

5,160 99.6% 5,160 99.6% 0.0%
Trace too long

A trace is truncated because it is longer than the instruction buffer.

0 0.0% 0 0.0%
Trace too short

A potential trace is abandoned because it it too short.

5,160 99.6% 5,160 99.6% 0.0%
Inner loop found

A trace is truncated because it has an inner loop

0 0.0% 0 0.0%
Recursive call

A trace is truncated because it has a recursive call.

0 0.0% 0 0.0%
Low confidence

A trace is abandoned because the likelihood of the jump to top being taken is too low.

0 0.0% 0 0.0%
Executors invalidated

The number of executors that were invalidated due to watched dictionary changes.

0 0.0% 0 0.0%
Traces executed

The number of traces that were executed

87,408,680 87,408,680 0.0%
Uops executed

The total number of uops (micro-operations) that were executed

3,486,596,460 3,988.8% 3,486,596,460 3,988.8% 0.0%
Base Count Base Ratio Head Count Head Ratio Change
Optimizer attempts

The number of times the trace optimizer (_Py_uop_analyze_and_optimize) was run.

20 20 0.0%
Optimizer successes

The number of traces that were successfully optimized.

20 100.0% 20 100.0% 0.0%
Optimizer no memory

The number of optimizations that failed due to no memory.

0 0.0% 0 0.0%
Remove globals builtins changed

The builtins changed during optimization

0 0.0% 0 0.0%
Remove globals incorrect keys

The keys in the globals dictionary aren't what was expected

0 0.0% 0 0.0%

Trace length histogram

trace length histogram
Range Base Count Base Ratio Head Count Head Ratio Change
<= 1 0 0.0% 0 0.0%
<= 2 0 0.0% 0 0.0%
<= 4 0 0.0% 0 0.0%
<= 8 20 100.0% 20 100.0% 0.0%

Optimized trace length histogram

optimized trace length histogram
Range Base Count Base Ratio Head Count Head Ratio Change
<= 1 0 0.0% 0 0.0%
<= 2 0 0.0% 0 0.0%
<= 4 20 100.0% 20 100.0% 0.0%

Trace run length histogram

trace run length histogram
Range Base Count Base Ratio Head Count Head Ratio Change
<= 1 0 0.0% 0 0.0%

Uop execution stats

uop execution stats
Name Base Count Head Count Change
_SET_IP 412,876,680 412,876,680 0.0%
_CHECK_VALIDITY 364,707,780 364,707,780 0.0%
_CHECK_PERIODIC 180,879,360 180,879,360 0.0%
_MAKE_WARM 156,713,000 156,713,000 0.0%
_GUARD_TYPE_VERSION 144,015,360 144,015,360 0.0%
_GUARD_NOT_EXHAUSTED_LIST 129,269,760 129,269,760 0.0%
_ITER_CHECK_LIST 129,269,760 129,269,760 0.0%
_ITER_NEXT_LIST 117,473,280 117,473,280 0.0%
_CHECK_MANAGED_OBJECT_HAS_VALUES 102,727,680 102,727,680 0.0%
_LOAD_ATTR_INSTANCE_VALUE 102,727,680 102,727,680 0.0%
_START_EXECUTOR 87,408,680 87,408,680 0.0%
_EXIT_TRACE 86,917,220 86,917,220 0.0%
_LOAD_FAST_2 86,507,460 86,507,460 0.0%
_LIST_APPEND 73,728,000 73,728,000 0.0%
_JUMP_TO_TOP 69,304,320 69,304,320 0.0%
_CHECK_VALIDITY_AND_SET_IP 67,338,240 67,338,240 0.0%
_STORE_FAST_4 62,914,500 62,914,500 0.0%
_LOAD_FAST_3 61,931,520 61,931,520 0.0%
_LOAD_FAST_1 60,456,960 60,456,960 0.0%
_LOAD_METHOD_NO_DICT 53,575,680 53,575,680 0.0%
_CALL_METHOD_DESCRIPTOR_FAST 53,084,160 53,084,160 0.0%
_LOAD_FAST_4 53,084,160 53,084,160 0.0%
_STORE_FAST_2 40,304,640 40,304,640 0.0%
_POP_TOP 35,389,440 35,389,440 0.0%
_SWAP 31,948,800 31,948,800 0.0%
_GET_ITER 31,457,280 31,457,280 0.0%
_LOAD_FAST_0 31,457,280 31,457,280 0.0%
_PUSH_FRAME 30,474,180 30,474,180 0.0%
_CHECK_FUNCTION_EXACT_ARGS 29,982,720 29,982,720 0.0%
_CHECK_FUNCTION_VERSION 29,982,720 29,982,720 0.0%
_SAVE_RETURN_OFFSET 29,982,720 29,982,720 0.0%
_LOAD_CONST_INLINE 29,982,660 29,982,660 0.0%
_BINARY_SUBSCR_DICT 26,542,080 26,542,080 0.0%
_RESUME_CHECK 21,135,360 21,135,360 0.0%
_GUARD_DORV_VALUES_INST_ATTR_FROM_DICT 21,135,360 21,135,360 0.0%
_GUARD_KEYS_VERSION 21,135,360 21,135,360 0.0%
_INIT_CALL_PY_EXACT_ARGS_1 21,135,360 21,135,360 0.0%
_LOAD_METHOD_WITH_VALUES 21,135,360 21,135,360 0.0%
_CHECK_FUNCTION 21,135,300 21,135,300 0.0%
_CHECK_STACK_SPACE_OPERAND 20,643,840 20,643,840 0.0%
_PUSH_NULL 18,186,180 18,186,180 0.0%
_MAP_ADD 17,694,720 17,694,720 0.0%
_TO_BOOL_BOOL 17,694,720 17,694,720 0.0%
_LOAD_FAST_5 17,694,720 17,694,720 0.0%
_STORE_FAST_1 17,694,720 17,694,720 0.0%
_RETURN_VALUE 14,745,600 14,745,600 0.0%
_GUARD_IS_TRUE_POP 11,796,480 11,796,480 0.0%
_COPY 11,796,480 11,796,480 0.0%
_LOAD_FAST_AND_CLEAR 11,796,480 11,796,480 0.0%
_COMPARE_OP 11,796,480 11,796,480 0.0%
_LOAD_ATTR 11,796,480 11,796,480 0.0%
_BUILD_LIST 10,813,440 10,813,440 0.0%
_LOAD_CONST_INLINE_BORROW 9,830,400 9,830,400 0.0%
_STORE_FAST_7 9,338,880 9,338,880 0.0%
_TO_BOOL_NONE 8,847,360 8,847,360 0.0%
_MAKE_FUNCTION 8,847,360 8,847,360 0.0%
_RETURN_GENERATOR 8,847,360 8,847,360 0.0%
_BUILD_TUPLE 8,847,360 8,847,360 0.0%
_CALL_LEN 8,847,360 8,847,360 0.0%
_BINARY_SUBSCR 8,847,360 8,847,360 0.0%
_CALL_BUILTIN_O 8,847,360 8,847,360 0.0%
_COMPARE_OP_INT 8,847,360 8,847,360 0.0%
_GUARD_BOTH_INT 8,847,360 8,847,360 0.0%
_GUARD_BUILTINS_VERSION_PUSH_KEYS 8,847,360 8,847,360 0.0%
_GUARD_GLOBALS_VERSION 8,847,360 8,847,360 0.0%
_INIT_CALL_PY_EXACT_ARGS_0 8,847,360 8,847,360 0.0%
_LOAD_FAST_7 8,847,360 8,847,360 0.0%
_LOAD_GLOBAL_BUILTINS_FROM_KEYS 8,847,360 8,847,360 0.0%
_GUARD_IS_FALSE_POP 5,898,240 5,898,240 0.0%
_GUARD_DORV_NO_DICT 1,474,560 1,474,560 0.0%
_GUARD_TYPE_VERSION_AND_LOCK 1,474,560 1,474,560 0.0%
_STORE_ATTR_INSTANCE_VALUE 1,474,560 1,474,560 0.0%
_BUILD_MAP 983,040 983,040 0.0%
_LOAD_FAST_6 983,040 983,040 0.0%
_GUARD_NOT_EXHAUSTED_RANGE 491,520 491,520 0.0%
_CALL_METHOD_DESCRIPTOR_FAST_WITH_KEYWORDS 491,520 491,520 0.0%
_ITER_CHECK_RANGE 491,520 491,520 0.0%
_STORE_FAST_3 491,520 491,520 0.0%
_STORE_FAST_5 491,520 491,520 0.0%
_STORE_FAST_6 491,520 491,520 0.0%
_TIER2_RESUME_CHECK 491,520 491,520 0.0%
_CHECK_AND_ALLOCATE_OBJECT 491,460 491,460 0.0%
_CREATE_INIT_FRAME 491,460 491,460 0.0%
_DYNAMIC_EXIT 491,460 491,460 0.0%
_ITER_NEXT_RANGE 491,460 491,460 0.0%
_LOAD_SMALL_INT_1 491,460 491,460 0.0%

Pair counts

Pair counts for top 100 Non-JIT uop pairs

Pairs of specialized operations that deoptimize and are then followed by the corresponding unspecialized instruction are not counted as pairs.

Not included in comparative output.

Unsupported opcodes

unsupported opcodes

Optimizer errored out with opcode

Optimization stopped after encountering this opcode

Rare events

Counts of rare/unlikely events
Event Base Count Head Count Change
set class

Setting an object's class, obj.__class__ = ...

0 0
set bases

Setting the bases of a class, cls.__bases__ = ...

0 0
set eval frame func

Setting the PEP 523 frame eval function _PyInterpreterState_SetFrameEvalFunc()

0 0
builtin dict

Modifying the builtins, __builtins__.__dict__[var] = ...

0 0
func modification

Modifying a function, e.g. func.__defaults__ = ..., etc.

0 0
watched dict modification

A watched dict has been modified

0 0
watched globals modification

A watched globals() dict has been modified

0 0

Meta stats

Meta statistics
Base Count Head Count Change
Number of data files 20 20 0.0%

Stats gathered on: 2025-01-22