|
|
|
import os |
|
import json |
|
|
|
import numpy as np |
|
import pandas as pd |
|
import matplotlib as mpl |
|
import seaborn as sns |
|
|
|
|
|
def main(): |
|
|
|
datasets = ["mnist", "fmnist", "cifar10"] |
|
selected_epochs_dict = {"mnist":[5],"fmnist":[2,6,11], "cifar10":[3,9,18,41]} |
|
|
|
col = np.array(["dataset", "method", "type", "hue", "period", "eval"]) |
|
df = pd.DataFrame({}, columns=col) |
|
|
|
for i in range(len(datasets)): |
|
dataset = datasets[i] |
|
data = np.array([]) |
|
selected_epochs = selected_epochs_dict[dataset] |
|
|
|
|
|
eval_path = "/home/xianglin/projects/DVI_data/resnet18_{}/Model/test_evaluation_hybrid.json".format(dataset) |
|
with open(eval_path, "r") as f: |
|
eval = json.load(f) |
|
for epoch_id in range(len(selected_epochs)): |
|
epoch = selected_epochs[epoch_id] |
|
nn_train = round(eval["tlr_train"][str(epoch)], 3) |
|
nn_test = round(eval["tlr_test"][str(epoch)], 3) |
|
|
|
if len(data) == 0: |
|
data = np.array([[dataset, "DeepDebugger", "Train", "DeepDebugger(Train)", "{}".format(str(epoch)), nn_train]]) |
|
else: |
|
data = np.concatenate((data, np.array([[dataset, "DeepDebugger", "Train", "DeepDebugger(Train)", "{}".format(str(epoch)), nn_train]])), axis=0) |
|
data = np.concatenate((data, np.array([[dataset, "DeepDebugger", "Test", "DeepDebugger(Test)", "{}".format(str(epoch)), nn_test]])), axis=0) |
|
|
|
|
|
eval_path = "/home/xianglin/projects/DVI_data/resnet18_{}/Model/without_smoothness/test_evaluation_hybrid.json".format(dataset) |
|
with open(eval_path, "r") as f: |
|
eval = json.load(f) |
|
for epoch_id in range(len(selected_epochs)): |
|
epoch = selected_epochs[epoch_id] |
|
nn_train = round(eval["tlr_train"][str(epoch)], 3) |
|
nn_test = round(eval["tlr_test"][str(epoch)], 3) |
|
|
|
data = np.concatenate((data, np.array([[dataset, "no_Smoothness", "Train", "-SS(Train)", "{}".format(str(epoch)), nn_train]])), axis=0) |
|
data = np.concatenate((data, np.array([[dataset, "no_Smoothness", "Test", "-SS(Test)", "{}".format(str(epoch)), nn_test]])), axis=0) |
|
|
|
|
|
eval_path = "/home/xianglin/projects/DVI_data/resnet18_{}/Model/without_tl/test_evaluation_hybrid.json".format(dataset) |
|
with open(eval_path, "r") as f: |
|
eval = json.load(f) |
|
for epoch_id in range(len(selected_epochs)): |
|
epoch = selected_epochs[epoch_id] |
|
nn_train = round(eval["tlr_train"][str(epoch)], 3) |
|
nn_test = round(eval["tlr_test"][str(epoch)], 3) |
|
|
|
data = np.concatenate((data, np.array([[dataset, "no_TL", "Train", "-TL(Train)", "{}".format(str(epoch)), nn_train]])), axis=0) |
|
data = np.concatenate((data, np.array([[dataset, "no_TL", "Test", "-TL(Test)", "{}".format(str(epoch)), nn_test]])), axis=0) |
|
|
|
df_tmp = pd.DataFrame(data, columns=col) |
|
df = df.append(df_tmp, ignore_index=True) |
|
df[["period"]] = df[["period"]].astype(int) |
|
df[["eval"]] = df[["eval"]].astype(float) |
|
|
|
df.to_excel("./plot_results/ablation_smoothness_nn.xlsx") |
|
|
|
pal20c = sns.color_palette('tab20', 20) |
|
sns.set_theme(style="whitegrid", palette=pal20c) |
|
hue_dict = { |
|
"-TL(Train)": pal20c[10], |
|
"-SS(Train)": pal20c[12], |
|
"DeepDebugger(Train)": pal20c[18], |
|
|
|
"-TL(Test)": pal20c[11], |
|
"-SS(Test)": pal20c[13], |
|
"DeepDebugger(Test)": pal20c[19], |
|
} |
|
sns.palplot([hue_dict[i] for i in hue_dict.keys()]) |
|
|
|
axes = {'labelsize': 15, |
|
'titlesize': 15,} |
|
mpl.rc('axes', **axes) |
|
mpl.rcParams['xtick.labelsize'] = 15 |
|
|
|
|
|
hue_list = ["-TL(Train)","-TL(Test)","-SS(Train)", "-SS(Test)", "DeepDebugger(Train)", "DeepDebugger(Test)"] |
|
|
|
fg = sns.catplot( |
|
x="period", |
|
y="eval", |
|
hue="hue", |
|
hue_order=hue_list, |
|
|
|
|
|
col="dataset", |
|
ci=0.001, |
|
height=2.5, |
|
aspect=1.0, |
|
data=df, |
|
sharex=False, |
|
kind="bar", |
|
palette=[hue_dict[i] for i in hue_list], |
|
legend=True |
|
) |
|
sns.move_legend(fg, "lower center", bbox_to_anchor=(.42, 0.92), ncol=2, title=None, frameon=False) |
|
mpl.pyplot.setp(fg._legend.get_texts(), fontsize='15') |
|
|
|
axs = fg.axes[0] |
|
|
|
|
|
|
|
axs[0].set_title("MNIST(20)") |
|
axs[1].set_title("FMNIST(50)") |
|
axs[2].set_title("CIFAR-10(200)") |
|
|
|
(fg.despine(bottom=False, right=False, left=False, top=False) |
|
|
|
.set_axis_labels("", "") |
|
) |
|
|
|
|
|
fg.savefig( |
|
"./plot_results/ablation_smoothness_tlr.png", |
|
dpi=300, |
|
bbox_inches="tight", |
|
pad_inches=0.0, |
|
transparent=True, |
|
) |
|
|
|
|
|
if __name__ == "__main__": |
|
main() |
|
|
|
|