gh-116879: Add new optimizer pystats to tables (GH-116880)

This commit is contained in:
Michael Droettboom 2024-03-16 11:10:43 -04:00 committed by GitHub
parent bee7e290cd
commit 1a33513f99
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -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"),