-
Notifications
You must be signed in to change notification settings - Fork 16
Visualization
Alexander Viand edited this page Jul 31, 2020
·
7 revisions
The automatic benchmarking system starts a set of AWS EC2 instances that carry out the various benchmark runs. The results are saved as *.csv
files into the S3 bucket sok-repository-eval-benchmarks. In addition to the raw results, we also create plots and use an interactive visualization website.
For each benchmarking application (e.g. cardio
), there should exist a corresponding Python file in S3 (e.g. <timestamp_of_run>/plot/plot_cardio.py
).
Inside, the code should define a function plot(..)
that takes a list of labels (i.e. tool names), a list of pandas dataframes (each tool's *.csv
) and optionally a matplotlib Figure object to draw into. The function should return the Figure containing the desired plot.
For example, plot_cardio.py
:
from typing import List
import matplotlib.pyplot as plt
import pandas as pd
import numpy as np
def plot(labels: List[str], pandas_dataframes: List[pd.DataFrame], fig=None) -> plt.Figure:
"""
:param labels:
:param pandas_dataframes:
:param fig:
:return:
"""
# Save current figure to restore later
previous_figure = plt.gcf()
# Set the current figure to fig
if fig is None:
fig = plt.figure()
plt.figure(fig.number)
# Setup Axis, Title, etc
N = len(labels)
plt.title('Runtime for Cardio')
plt.ylabel('Time (ms)')
ind = np.arange(N) # the x locations for the groups
plt.xticks(ind, labels)
width = 0.35 # the width of the bars: can also be len(x) sequence
# Plot Bars
for i in range(N):
df = pandas_dataframes[i]
p1 = plt.bar(ind[i], df['t_keygen'].mean(), width, color='red')
p2 = plt.bar(ind[i], df['t_input_encryption'][i], width, bottom=df['t_keygen'].mean(), color='blue')
p3 = plt.bar(ind[i], df['t_computation'][i], width, bottom=df['t_input_encryption'].mean(), color='green')
p4 = plt.bar(ind[i], df['t_decryption'][i], width, bottom=df['t_computation'].mean(), color='cyan')
# Add Legend
plt.legend((p4[0], p3[0], p2[0], p1[0]), ('Decryption', 'Computation', 'Encryption', 'Key Generation'))
# Restore current figure
plt.figure(previous_figure.number)
return fig
if __name__ == '__main__':
print("Testing ploting with cardio example")
data = [pd.read_csv('s3://sok-repository-eval-benchmarks/20200729_094952/Cingulata/cingulata_cardio.csv')]
labels = ['Cingulata']
plot(labels, data)
- Home
- Compilers & Optimizations
- Libraries
- Benchmark Programs
- Implementation Docs