add option to save dfs

Signed-off-by: fei.zheng <fei.zheng@amd.com>


[ROCm/rocprofiler-compute commit: 1104371651]
这个提交包含在:
fei.zheng
2023-05-03 17:45:29 -06:00
父节点 9e42cd9ef1
当前提交 c8df0bf75f
修改 3 个文件,包含 27 行新增9 行删除
@@ -209,6 +209,7 @@ def run_cli(args, runs):
runs,
archConfigs["gfx90a"],
output,
args.df_file_dir,
args.decimal,
args.time_unit,
args.cols,
@@ -23,6 +23,7 @@
##############################################################################el
import pandas as pd
from pathlib import Path
from tabulate import tabulate
from omniperf_analyze.utils import schema, parser
@@ -47,7 +48,8 @@ def string_multiple_lines(source, width, max_rows):
return "\n".join(lines)
def show_all(runs, archConfigs, output, decimal, time_unit, selected_cols, verbose):
def show_all(runs, archConfigs, output, df_file_dir, decimal, time_unit,
selected_cols, verbose):
"""
Show all panels with their data in plain text mode.
"""
@@ -152,15 +154,24 @@ def show_all(runs, archConfigs, output, decimal, time_unit, selected_cols, verbo
if not df.empty:
# subtitle for each table in a panel if existing
table_id_str = str(table_config["id"] // 100) + "." + str(
table_config["id"] % 100)
if "title" in table_config and table_config["title"]:
ss += (
str(table_config["id"] // 100)
+ "."
+ str(table_config["id"] % 100)
+ " "
+ table_config["title"]
+ "\n"
)
ss += (table_id_str + " " + table_config["title"] +
"\n")
if df_file_dir:
p = Path(df_file_dir)
if not p.exists():
p.mkdir()
if p.is_dir():
if "title" in table_config and table_config[
"title"]:
table_id_str += ("_" + table_config["title"])
df.to_csv(p.joinpath(
table_id_str.replace(" ", "_") + ".csv"),
index=False)
# NB:
# "columnwise: True" is a special attr of a table/df
@@ -468,6 +468,12 @@ def parse(my_parser):
default=2,
help="\t\tSpecify the decimal to display. (DEFAULT: 2)",
)
analyze_group.add_argument(
"--save-dfs",
dest="df_file_dir",
metavar="",
help="\t\tSpecify the dirctory to save analysis dataframe csv files.",
)
analyze_group.add_argument(
"--cols",
type=int,