diff --git a/benchmarks/nx-cugraph/pytest-based/create_results_summary_page.py b/benchmarks/nx-cugraph/pytest-based/create_results_summary_page.py index 0b2482c43ee..f1cc4b06ccc 100644 --- a/benchmarks/nx-cugraph/pytest-based/create_results_summary_page.py +++ b/benchmarks/nx-cugraph/pytest-based/create_results_summary_page.py @@ -21,6 +21,66 @@ import subprocess +def get_formatted_time_value(time): + res = "" + if time < 1: + if time < 0.001: + units = "us" + time *= 1e6 + else: + units = "ms" + time *= 1e3 + else: + units = "s" + return f"{time:.3f}{units}" + + +def get_all_benchmark_info(): + benchmarks = {} + # Populate benchmarks dir from .json files + for json_file in logs_dir.glob("*.json"): + try: + data = json.loads(open(json_file).read()) + except json.decoder.JSONDecodeError: + continue + + for benchmark_run in data["benchmarks"]: + # example name: "bench_triangles[ds=netscience-backend=cugraph-preconverted]" + name = benchmark_run["name"] + + algo_name = name.split("[")[0] + if algo_name.startswith("bench_"): + algo_name = algo_name[6:] + # special case for betweenness_centrality + match = k_patt.match(name) + if match is not None: + algo_name += f", k={match.group(1)}" + + match = dataset_patt.match(name) + if match is None: + raise RuntimeError( + f"benchmark name {name} in file {json_file} has an unexpected format" + ) + dataset = match.group(1) + if dataset.endswith("-backend"): + dataset = dataset[:-8] + + match = backend_patt.match(name) + if match is None: + raise RuntimeError( + f"benchmark name {name} in file {json_file} has an unexpected format" + ) + backend = match.group(1) + if backend == "None": + backend = "networkx" + + runtime = benchmark_run["stats"]["mean"] + benchmarks.setdefault(algo_name, {}).setdefault(backend, {})[ + dataset + ] = runtime + return benchmarks + + def compute_perf_vals(cugraph_runtime, networkx_runtime): speedup_string = f"{networkx_runtime / cugraph_runtime:.3f}X" delta = networkx_runtime - cugraph_runtime @@ -77,16 +137,17 @@ def get_first_gpu_info(): def get_system_info(): + print('
') print(f"

Hostname: {socket.gethostname()}

") print( - f'

Operating System: {platform.system()} {platform.release()}

' + f'

Operating System: {platform.system()} {platform.release()}

' ) - print(f'

Kernel Version : {platform.version()}

') + print(f'

Kernel Version : {platform.version()}

') with open("/proc/cpuinfo") as f: print( f'

CPU: {next(line.strip().split(": ")[1] for line in f if "model name" in line)} ({psutil.cpu_count(logical=False)} cores)

' ) - print(f'

Memory: {get_mem_info()} GB

') + print(f'

Memory: {get_mem_info()} GB

') print(f"

GPU: {get_first_gpu_info()}

") print(f"

CUDA Version: {get_cuda_version()}

") @@ -99,51 +160,7 @@ def get_system_info(): k_patt = re.compile(".*k=(10*).*") # Organize all benchmark runs by the following hierarchy: algo -> backend -> dataset - benchmarks = {} - - # Populate benchmarks dir from .json files - for json_file in logs_dir.glob("*.json"): - # print(f"READING {json_file}") - try: - data = json.loads(open(json_file).read()) - except json.decoder.JSONDecodeError: - # print(f"PROBLEM READING {json_file}, skipping.") - continue - - for benchmark_run in data["benchmarks"]: - # example name: "bench_triangles[ds=netscience-backend=cugraph-preconverted]" - name = benchmark_run["name"] - - algo_name = name.split("[")[0] - if algo_name.startswith("bench_"): - algo_name = algo_name[6:] - # special case for betweenness_centrality - match = k_patt.match(name) - if match is not None: - algo_name += f", k={match.group(1)}" - - match = dataset_patt.match(name) - if match is None: - raise RuntimeError( - f"benchmark name {name} in file {json_file} has an unexpected format" - ) - dataset = match.group(1) - if dataset.endswith("-backend"): - dataset = dataset[:-8] - - match = backend_patt.match(name) - if match is None: - raise RuntimeError( - f"benchmark name {name} in file {json_file} has an unexpected format" - ) - backend = match.group(1) - if backend == "None": - backend = "networkx" - - runtime = benchmark_run["stats"]["mean"] - benchmarks.setdefault(algo_name, {}).setdefault(backend, {})[ - dataset - ] = runtime + benchmarks = get_all_benchmark_info() # dump HTML table ordered_datasets = [ @@ -184,17 +201,26 @@ def get_system_info(): } th, td { - padding: 10px; + padding: 12px; } - .footer { - background-color: #f1f1f1; - padding: 10px; + .footer-main { + background-color: #d1d1d1; + padding: 20px; + padding-top: 0px; font-size: 12px; color: black; width: 100%; + display: flex; + } + .box1{ + flex: 1; + padding-right: 30px; + } + .box2{ + flex: 4; } - .text-indent { - text-indent: 20px; /* Indents the first line of the text by 30px */ + .indent { + text-indent: 20px; } @@ -234,7 +260,11 @@ def get_system_info(): cugraph_runtime=cugraph_runtime, networkx_runtime=networkx_runtime, ) - print(f" {speedup}
{runtime_delta}") + nx_formatted = get_formatted_time_value(networkx_runtime) + cg_formatted = get_formatted_time_value(cugraph_runtime) + print( + f" {nx_formatted} / {cg_formatted}
{speedup}
{runtime_delta}" + ) else: print(f" ") @@ -243,13 +273,19 @@ def get_system_info(): else: for _ in range(len(ordered_datasets)): print(" ") - print(" ") - print( """ \n - \n
\n""")