-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_retrieval.py
44 lines (31 loc) · 1.3 KB
/
test_retrieval.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
import json
from tqdm import tqdm
import os
os.system('clear')
from util.model_util import SVRAG_InternVL2, SVRAG_Phi
from util.print_result import print_top_k_accuracy
import argparse
parser = argparse.ArgumentParser()
parser.add_argument("--model", default='InternVL2',
choices=['Phi3v', 'InternVL2'],
help="retriever name",
type=str)
args = parser.parse_args()
if __name__ == "__main__":
if args.model == 'Phi3v':
model = SVRAG_Phi(model_name='puar-playground/Col-Phi-3-V')
elif args.model == 'InternVL2':
model = SVRAG_InternVL2(model_name='puar-playground/Col-InternVL2-4B')
test_data = json.load(open('slidevqa_dev.json', 'r'))
results = []
pbar = tqdm(list(test_data.keys()), ncols=120)
for doc_id in pbar:
data_point = test_data[doc_id]
question_list = data_point['question']
image_list = data_point['image_urls']
true_indicies = data_point['index_list']
_, retrieved_indicies = model.retrieve(query_list=question_list, image_list=image_list)
retrieved_indicies = retrieved_indicies.tolist()
results.append([true_indicies, retrieved_indicies])
acc_str = print_top_k_accuracy(results, k_list=[1, 5])
pbar.set_description(acc_str)