improved showresults.py:
- added the ability to show the performance per clock cycle (eg to see if avx512 has an effect on the computation) - the cpus are now sorted on x axis depending on their generation work related to [https://bugzilla.ipr.univ-rennes.fr/show_bug.cgi?id=3372]
This commit is contained in:
		
							parent
							
								
									1423090328
								
							
						
					
					
						commit
						46d7fd1fa7
					
				|  | @ -252,9 +252,25 @@ class HibenchResultsParser(): | ||||||
|         return results |         return results | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| def create_graphs(sql_engine): | def get_cpu_freq(cpu_id: CpuId) -> float: | ||||||
|  |     return { | ||||||
|  |         'intel_xeon_x5550': 2.67, | ||||||
|  |         'intel_xeon_x5650': 2.67, | ||||||
|  |         'intel_xeon_e5-2660': 2.2, | ||||||
|  |         'intel_xeon_e5-2660v2': 2.2, | ||||||
|  |         'intel_xeon_e5-2660v4': 2.0, | ||||||
|  |         'intel_xeon_gold_5222': 3.8, | ||||||
|  |         'intel_xeon_gold_6140': 2.3, | ||||||
|  |         'intel_xeon_gold_6154': 3.0, | ||||||
|  |         'intel_xeon_gold_6226r': 2.9, | ||||||
|  |         'intel_xeon_gold_6248r': 3.0, | ||||||
|  |         'amd_epyc_7282': 2.8 | ||||||
|  |     }[cpu_id] * 10**9 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | def create_graph(sql_engine, per_clock: bool): | ||||||
|     with sql_engine.connect() as conn: |     with sql_engine.connect() as conn: | ||||||
|         bar_data = {} |         cpu_data = {} | ||||||
| 
 | 
 | ||||||
|         computation_id = 'nh3h2_qma_long' |         computation_id = 'nh3h2_qma_long' | ||||||
|         commit_ids = set() |         commit_ids = set() | ||||||
|  | @ -262,16 +278,29 @@ def create_graphs(sql_engine): | ||||||
|         for row in result: |         for row in result: | ||||||
|             print(row) |             print(row) | ||||||
|             (cpu_id, avg_duration, commit_id) = row |             (cpu_id, avg_duration, commit_id) = row | ||||||
|             if cpu_id not in bar_data.keys(): |             if cpu_id not in cpu_data.keys(): | ||||||
|                 bar_data[cpu_id] = {} |                 cpu_data[cpu_id] = {} | ||||||
|             cpu_perf = bar_data[cpu_id] |             commit_id_to_avg_duration = cpu_data[cpu_id] | ||||||
|             cpu_perf[commit_id] = avg_duration |             commit_id_to_avg_duration[commit_id] = avg_duration | ||||||
|             commit_ids.add(commit_id) |             commit_ids.add(commit_id) | ||||||
| 
 | 
 | ||||||
|         # print(mkl_perf) |         # print(mkl_perf) | ||||||
| 
 | 
 | ||||||
|  |         cpu_order = { | ||||||
|  |             'intel_xeon_x5550': 0, | ||||||
|  |             'intel_xeon_e5-2660': 1, | ||||||
|  |             'intel_xeon_e5-2660v2': 2, | ||||||
|  |             'intel_xeon_e5-2660v4': 3, | ||||||
|  |             'intel_xeon_gold_5222': 4, | ||||||
|  |             'intel_xeon_gold_6140': 5, | ||||||
|  |             'intel_xeon_gold_6154': 6, | ||||||
|  |             'intel_xeon_gold_6226r': 7, | ||||||
|  |             'intel_xeon_gold_6248r': 8, | ||||||
|  |             'amd_epyc_7282': 9 | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         fig, ax = plt.subplots() |         fig, ax = plt.subplots() | ||||||
|         cpu_ids = bar_data.keys() |         cpu_ids = sorted(cpu_data.keys(), key=lambda x: cpu_order[x]) | ||||||
|         x = np.arange(len(cpu_ids))  # the label locations |         x = np.arange(len(cpu_ids))  # the label locations | ||||||
|         bar_group_width = 0.8 |         bar_group_width = 0.8 | ||||||
|         bar_width = bar_group_width / len(commit_ids)  # the width of the bars |         bar_width = bar_group_width / len(commit_ids)  # the width of the bars | ||||||
|  | @ -279,22 +308,28 @@ def create_graphs(sql_engine): | ||||||
|         commit_index = 0 |         commit_index = 0 | ||||||
|         for commit_id in commit_ids: |         for commit_id in commit_ids: | ||||||
|             # print(f'commit {commit_id}') |             # print(f'commit {commit_id}') | ||||||
|             avg_durations = [] |             y = [] | ||||||
|             for cpu_id in cpu_ids: |             for cpu_id in cpu_ids: | ||||||
|                 perfs = bar_data[cpu_id] |                 commit_id_to_avg_duration = cpu_data[cpu_id] | ||||||
|                 # print(perfs) |                 # print(perfs) | ||||||
|                 if commit_id in perfs: |                 cpu_y = 0.0 | ||||||
|                     avg_duration = perfs[commit_id] |                 print(commit_id_to_avg_duration) | ||||||
|                 else: |                 if commit_id in commit_id_to_avg_duration: | ||||||
|                     avg_duration = 0.0 |                     cpu_y = 1.0 / commit_id_to_avg_duration[commit_id] | ||||||
|                 avg_durations.append(avg_duration) |                 if per_clock: | ||||||
|  |                     cpu_y /= get_cpu_freq(cpu_id) | ||||||
|  |                 y.append(cpu_y) | ||||||
|             bar_x_pos = x - bar_group_width * 0.5 + bar_group_width * ((commit_index + 0.5) / len(commit_ids)) |             bar_x_pos = x - bar_group_width * 0.5 + bar_group_width * ((commit_index + 0.5) / len(commit_ids)) | ||||||
|             print(commit_index, bar_x_pos) |             print(commit_index, bar_x_pos) | ||||||
|             rects = ax.bar(bar_x_pos, avg_durations, bar_width, label=f'hibridon {commit_id}') |             rects = ax.bar(bar_x_pos, y, bar_width, label=f'hibridon {commit_id}') | ||||||
|             commit_index += 1 |             commit_index += 1 | ||||||
| 
 | 
 | ||||||
|         # Add some text for labels, title and custom x-axis tick labels, etc. |         # Add some text for labels, title and custom x-axis tick labels, etc. | ||||||
|         ax.set_ylabel('computation duration (s)') |         if per_clock: | ||||||
|  |             ylabel = 'number of computations per cpu clock for a core' | ||||||
|  |         else: | ||||||
|  |             ylabel = 'number of computations per second for a core' | ||||||
|  |         ax.set_ylabel(ylabel) | ||||||
|         ax.set_title(f'hibridon\'s {computation_id} performance (serial code) on various cpus') |         ax.set_title(f'hibridon\'s {computation_id} performance (serial code) on various cpus') | ||||||
|         ax.set_xticks(x) |         ax.set_xticks(x) | ||||||
|         ax.tick_params(axis='x', labelrotation=45) |         ax.tick_params(axis='x', labelrotation=45) | ||||||
|  | @ -340,6 +375,10 @@ def create_graphs(sql_engine): | ||||||
|         plt.show() |         plt.show() | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | def create_graphs(sql_engine): | ||||||
|  |     create_graph(sql_engine, per_clock=True) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| def main(): | def main(): | ||||||
| 
 | 
 | ||||||
|     # 20240927-20:03:18 graffy@graffy-ws2:~/work/starbench/starbench.git$ rsync -va graffy@physix.ipr.univ-rennes1.fr:/opt/ipr/cluster/work.global/graffy/hibridon/benchmarks/starbench/ ./usecases/ipr/hibench/results/ |     # 20240927-20:03:18 graffy@graffy-ws2:~/work/starbench/starbench.git$ rsync -va graffy@physix.ipr.univ-rennes1.fr:/opt/ipr/cluster/work.global/graffy/hibridon/benchmarks/starbench/ ./usecases/ipr/hibench/results/ | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue