import json
import time

# CT, Cric, IO, ND, TQ
# 0, 1, 2, 3, 4, 5
# question x_xx_xxxxx_xx
# procedure_videonumber_framenumber_questionnumber

annotation_file = '../data_arrows/root/test_annotations.json'
test_file = './vqa/result/vqa_submit_vilt_vqa.json'


with open(annotation_file, 'r') as input_file:
    annotations = json.load(input_file)

with open(test_file, 'r') as input_file:
    test_answers = json.load(input_file)

correct = 0
total = 0
last_time = time.time()

for idx, qa in enumerate(test_answers):
    qid_test = qa['question_id']
    ans_test = qa['answer']
    for annotation in annotations['annotations']:
        qid_gt = annotation['question_id']
        ans_gt = annotation['multiple_choice_answer']
        if qid_gt == qid_test:
            total += 1
            if ans_gt == ans_test:
                correct += 1
            annotations['annotations'].remove(annotation)
    if idx % int(len(test_answers)/100) == 0 and idx != 0:
        current_time = time.time()
        print('processed ' + str(round(idx/len(test_answers), 2))
            + ', time: ' + str(round(current_time-last_time, 2)))
        last_time = current_time

print('accuracy: ' + str(correct/total))

