-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathattack_results_statistical.py
44 lines (37 loc) · 1.67 KB
/
attack_results_statistical.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
import json
import config
import numpy as np
def main():
args= config.parse()
print(args)
# datasets_list =['nq','msmarco']
datasets_list_dic= [('nq-train','nq'),('msmarco','msmarco')]
model_code_list = [ "contriever", "contriever-msmarco", "dpr-single" ,"dpr-multi" ,"ance" ,"tas-b" ,"dragon"]
seed_list = [1999, 5, 27, 2016, 2024]
k_list = [1 ,10 ,50]
for datasets_list in datasets_list_dic:
for model_code in model_code_list:
for k in k_list:
top_20_list = []
for seed in seed_list:
sub_dir = 'results/attack_results/%s/%s-%s' % (args.method, datasets_list[0], model_code)
filename = '%s/%s-%s-k%d-seed%d-num_cand%d-num_iter%d-tokens%d.json' % (
sub_dir, datasets_list[1], model_code, k, seed, args.num_cand, args.num_iter,
args.num_adv_passage_tokens)
# if os.path.isfile(filename):
# return
with open(filename, 'r', encoding='utf-8') as file:
data = json.load(file)
# print(data)
top_20_list.append(data['Recall@20']*100)
top_20_np =np.array(top_20_list)
mean = np.mean(top_20_np)
std = np.std(top_20_np)
var = np.var(top_20_np)
print("datasets_list: ",datasets_list," model_code: ",model_code," k: ",k," seed_list: ",seed_list )
print("top_20_np: ", top_20_np)
print("mean: ",mean)
print("std: ",std)
print("var: ",var)
if __name__ == '__main__':
main()