moe-llava

Форк
0
/
convert_vizwiz_for_submission.py 
47 строк · 1.4 Кб
1
import os
2
import argparse
3
import json
4

5
from moellava.eval.m4c_evaluator import EvalAIAnswerProcessor
6

7

8
def parse_args():
9
    parser = argparse.ArgumentParser()
10
    parser.add_argument('--annotation-file', type=str, required=True)
11
    parser.add_argument('--result-file', type=str, required=True)
12
    parser.add_argument('--result-upload-file', type=str, required=True)
13
    return parser.parse_args()
14

15

16
if __name__ == '__main__':
17

18
    args = parse_args()
19

20
    os.makedirs(os.path.dirname(args.result_upload_file), exist_ok=True)
21

22
    results = []
23
    error_line = 0
24
    for line_idx, line in enumerate(open(args.result_file)):
25
        try:
26
            results.append(json.loads(line))
27
        except:
28
            error_line += 1
29
    results = {x['question_id']: x['text'] for x in results}
30
    test_split = [json.loads(line) for line in open(args.annotation_file)]
31
    split_ids = set([x['question_id'] for x in test_split])
32

33
    print(f'total results: {len(results)}, total split: {len(test_split)}, error_line: {error_line}')
34

35
    all_answers = []
36

37
    answer_processor = EvalAIAnswerProcessor()
38

39
    for x in test_split:
40
        assert x['question_id'] in results
41
        all_answers.append({
42
            'image': x['image'],
43
            'answer': answer_processor(results[x['question_id']])
44
        })
45

46
    with open(args.result_upload_file, 'w') as f:
47
        json.dump(all_answers, f)
48

Использование cookies

Мы используем файлы cookie в соответствии с Политикой конфиденциальности и Политикой использования cookies.

Нажимая кнопку «Принимаю», Вы даете АО «СберТех» согласие на обработку Ваших персональных данных в целях совершенствования нашего веб-сайта и Сервиса GitVerse, а также повышения удобства их использования.

Запретить использование cookies Вы можете самостоятельно в настройках Вашего браузера.