forked from BruceW91/CVSE
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathevaluate.py
59 lines (49 loc) · 3.69 KB
/
evaluate.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
import argparse
from vocab import Vocabulary
import evaluation
from model_CVSE import CVSE
'''1) Evaluate COCO'''
parser = argparse.ArgumentParser(description='WILDCAT evaluate')
parser.add_argument('--data_path', default='../Bottom-up-atten-feature/data/', help='path to dataset ')
parser.add_argument('--data_name', default='coco_precomp', help='{coco,f30k}_precomp')
parser.add_argument('--model_path', default='./runs/coco/CVSE_COCO/model_best.pth.tar',help='Path to load the model.')
parser.add_argument('--vocab_path', default='./vocab/', help='Path to saved vocabulary json files.')
parser.add_argument('--data_name_vocab', default='coco_precomp', help='{coco,f30k}_precomp')
parser.add_argument('--transfer_test', action='store_true', help='Whether to perform cross-dataset testing.')
parser.add_argument('--split', default='test', help='Choose to evaluate on coco 1k test set or 5k test set. (test | testall)') # 1k test set
# parser.add_argument('--split', default='testall', help='Choose to evaluate on 1k test set or 5k test set. (test | testall)') # 5k test set
parser.add_argument('--concept_path', default='data/coco_to_f30k_annotations/Concept_annotations/',
help='path to load the concept data')
'''2) Evaluate f30k'''
# parser = argparse.ArgumentParser(description='WILDCAT evaluate')
# parser.add_argument('--data_path', default='../Bottom-up-atten-feature/data/', help='path to dataset ')
# parser.add_argument('--data_name', default='f30k_precomp', help='{coco,f30k}_precomp')
# parser.add_argument('--model_path', default='./runs/f30k/CVSE_f30k/model_best.pth.tar',help='Path to load the model.')
# parser.add_argument('--vocab_path', default='./vocab/', help='Path to saved vocabulary json files.')
# parser.add_argument('--data_name_vocab', default='f30k_precomp', help='{coco,f30k}_precomp')
# parser.add_argument('--transfer_test', action='store_true', help='Whether to perform cross-dataset testing.')
# parser.add_argument('--split', default='test', help='Evaluate on f30k 1k test set. ')
# parser.add_argument('--concept_path', default='data/coco_to_f30k_annotations/Concept_annotations/',
# help='path to load the concept data')
'''3) Evaluate coco-to-f30k transfer'''
# parser = argparse.ArgumentParser(description='WILDCAT evaluate')
# parser.add_argument('--data_path', default='../Bottom-up-atten-feature/data/', help='path to dataset ')
# parser.add_argument('--data_name', default='f30k_precomp', help='{coco,f30k}_precomp')
# parser.add_argument('--model_path', default='./runs/coco/CVSE_COCO/model_best.pth.tar',help='Path to load the model.')
# parser.add_argument('--vocab_path', default='./vocab/', help='Path to saved vocabulary json files.')
# parser.add_argument('--data_name_vocab', default='coco_precomp', help='{coco,f30k}_precomp')
# parser.add_argument('--transfer_test', action='store_false', help='Whether to perform cross-dataset testing.')
# parser.add_argument('--concept_path', default='data/coco_to_f30k_annotations/Concept_annotations/',
# help='path to load the concept data')
def main_test():
global args
args = parser.parse_args()
if args.transfer_test != True:
evaluation.evalrank(model_path=args.model_path, data_path=args.data_path, data_name=args.data_name,
data_name_vocab=args.data_name_vocab, split=args.split, VSE_model=CVSE)
else:
evaluation.evalrank(model_path=args.model_path, data_path=args.data_path, data_name=args.data_name,
data_name_vocab=args.data_name_vocab, split="test", VSE_model=CVSE,
concept_path=args.concept_path, transfer_test=True)
if __name__ == '__main__':
main_test()