forked from ivadomed/MEEG-Brainstorm
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathplot_per_subject.py
66 lines (53 loc) · 2.44 KB
/
plot_per_subject.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
import pandas as pd
import argparse
import matplotlib.pyplot as plt
from pathlib import Path
import seaborn as sns
def get_parser():
"""Set parameters for the experiment."""
parser = argparse.ArgumentParser(
"spike detection", description="spike detection using attention layer"
)
parser.add_argument("--path_data", type=str, default="../results/csv")
parser.add_argument("--n_subjects", type=int, default=1)
return parser
# Experiment name
parser = get_parser()
args = parser.parse_args() # you can modify this namespace for quick iterations
path_data = args.path_data
n_subjects = args.n_subjects
fnames = list(
Path(path_data).glob("results_intra_subject_spike_detection_method-*_{}-subjects.csv".format(n_subjects))
)
df = pd.concat([pd.read_csv(fname) for fname in fnames], axis=0)
df["method"] = df["method"].replace({"transformer_classification": "STT"})
# fig = plt.figure()
# sns.boxplot(data=df.groupby(['method', 'subject_id']).mean().reset_index(), x="method", y="f1_macro", palette="Set2")
# sns.swarmplot(data=df.groupby(['method', 'subject_id']).mean().reset_index(), x="method", y="f1_macro", color=".25")
# plt.legend([],[], frameon=False)
# plt.title(f"Results for F1 score")
# plt.tight_layout()
# fig.savefig(
# "../results/images/results_f1_score_intra_{}_subjects.pdf".format(n_subjects),
# bbox_inches="tight",
# )
# fig = plt.figure()
# sns.boxplot(data=df.groupby(['method', 'subject_id']).mean().reset_index(), x="method", y="recall_macro", palette="Set2" )
# sns.swarmplot(data=df.groupby(['method', 'subject_id']).mean().reset_index(), x="method", y="recall_macro", color=".25")
# plt.title(f"Results for accuracy score")
# plt.tight_layout()
# fig.savefig(
# "../results/images/results_acc_score_intra_{}_subjects.pdf".format(n_subjects),
# bbox_inches="tight",
# )
g = sns.FacetGrid(df, row="mix_up", col="cost_sensitive", margin_titles=True)
g.map(sns.boxplot, "weight_loss", "f1", "method", palette="Set2") #, fit_reg=False, x_jitter=.1)
g.map(sns.swarmplot, "weight_loss", "f1", "subject_id", palette="Set2") #, fit_reg=False, x_jitter=.1)
g.add_legend()
g.fig.suptitle('Intra sujet')
g.savefig(
"../results/images/results_intra_subject_F1_score_{}_subjects.pdf".format(n_subjects),
bbox_inches="tight",
)
print(df.groupby(['method', 'mix_up', 'cost_sensitive', 'weight_loss']).mean().reset_index())
print(df.groupby(['method', 'mix_up', 'cost_sensitive', 'weight_loss']).std().reset_index())