mirror of
				https://github.com/python/cpython.git
				synced 2025-10-26 19:24:34 +00:00 
			
		
		
		
	gh-116879: Add new optimizer pystats to tables (GH-116880)
This commit is contained in:
		
							parent
							
								
									bee7e290cd
								
							
						
					
					
						commit
						1a33513f99
					
				
					 1 changed files with 30 additions and 4 deletions
				
			
		|  | @ -459,10 +459,7 @@ def get_optimization_stats(self) -> dict[str, tuple[int, int | None]]: | ||||||
|                 "The number of times a potential trace is identified.  Specifically, this " |                 "The number of times a potential trace is identified.  Specifically, this " | ||||||
|                 "occurs in the JUMP BACKWARD instruction when the counter reaches a " |                 "occurs in the JUMP BACKWARD instruction when the counter reaches a " | ||||||
|                 "threshold.", |                 "threshold.", | ||||||
|             ): ( |             ): (attempts, None), | ||||||
|                 attempts, |  | ||||||
|                 None, |  | ||||||
|             ), |  | ||||||
|             Doc( |             Doc( | ||||||
|                 "Traces created", "The number of traces that were successfully created." |                 "Traces created", "The number of traces that were successfully created." | ||||||
|             ): (created, attempts), |             ): (created, attempts), | ||||||
|  | @ -512,6 +509,26 @@ def get_optimization_stats(self) -> dict[str, tuple[int, int | None]]: | ||||||
|             ), |             ), | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |     def get_optimizer_stats(self) -> dict[str, tuple[int, int | None]]: | ||||||
|  |         attempts = self._data["Optimization optimizer attempts"] | ||||||
|  |         successes = self._data["Optimization optimizer successes"] | ||||||
|  |         no_memory = self._data["Optimization optimizer failure no memory"] | ||||||
|  | 
 | ||||||
|  |         return { | ||||||
|  |             Doc( | ||||||
|  |                 "Optimizer attempts", | ||||||
|  |                 "The number of times the trace optimizer (_Py_uop_analyze_and_optimize) was run.", | ||||||
|  |             ): (attempts, None), | ||||||
|  |             Doc( | ||||||
|  |                 "Optimizer successes", | ||||||
|  |                 "The number of traces that were successfully optimized.", | ||||||
|  |             ): (successes, attempts), | ||||||
|  |             Doc( | ||||||
|  |                 "Optimizer no memory", | ||||||
|  |                 "The number of optimizations that failed due to no memory.", | ||||||
|  |             ): (no_memory, attempts), | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|     def get_histogram(self, prefix: str) -> list[tuple[int, int]]: |     def get_histogram(self, prefix: str) -> list[tuple[int, int]]: | ||||||
|         rows = [] |         rows = [] | ||||||
|         for k, v in self._data.items(): |         for k, v in self._data.items(): | ||||||
|  | @ -1118,6 +1135,14 @@ def calc_optimization_table(stats: Stats) -> Rows: | ||||||
|             for label, (value, den) in optimization_stats.items() |             for label, (value, den) in optimization_stats.items() | ||||||
|         ] |         ] | ||||||
| 
 | 
 | ||||||
|  |     def calc_optimizer_table(stats: Stats) -> Rows: | ||||||
|  |         optimizer_stats = stats.get_optimizer_stats() | ||||||
|  | 
 | ||||||
|  |         return [ | ||||||
|  |             (label, Count(value), Ratio(value, den)) | ||||||
|  |             for label, (value, den) in optimizer_stats.items() | ||||||
|  |         ] | ||||||
|  | 
 | ||||||
|     def calc_histogram_table(key: str, den: str) -> RowCalculator: |     def calc_histogram_table(key: str, den: str) -> RowCalculator: | ||||||
|         def calc(stats: Stats) -> Rows: |         def calc(stats: Stats) -> Rows: | ||||||
|             histogram = stats.get_histogram(key) |             histogram = stats.get_histogram(key) | ||||||
|  | @ -1159,6 +1184,7 @@ def iter_optimization_tables(base_stats: Stats, head_stats: Stats | None = None) | ||||||
|             return |             return | ||||||
| 
 | 
 | ||||||
|         yield Table(("", "Count:", "Ratio:"), calc_optimization_table, JoinMode.CHANGE) |         yield Table(("", "Count:", "Ratio:"), calc_optimization_table, JoinMode.CHANGE) | ||||||
|  |         yield Table(("", "Count:", "Ratio:"), calc_optimizer_table, JoinMode.CHANGE) | ||||||
|         for name, den in [ |         for name, den in [ | ||||||
|             ("Trace length", "Optimization traces created"), |             ("Trace length", "Optimization traces created"), | ||||||
|             ("Optimized trace length", "Optimization traces created"), |             ("Optimized trace length", "Optimization traces created"), | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Michael Droettboom
						Michael Droettboom