FinanceIQ_ppl_42b9bd.py 2.82 KB
Newer Older
1
2
3
4
5
6
7
from opencompass.openicl.icl_prompt_template import PromptTemplate
from opencompass.openicl.icl_retriever import FixKRetriever
from opencompass.openicl.icl_inferencer import PPLInferencer
from opencompass.openicl.icl_evaluator import AccEvaluator
from opencompass.datasets import FinanceIQDataset

financeIQ_subject_mapping_en = {
8
    'certified_public_accountant': '注册会计师(CPA)',
9
    'banking_qualification': '银行从业资格',
10
11
12
13
14
15
    'securities_qualification': '证券从业资格',
    'fund_qualification': '基金从业资格',
    'insurance_qualification': '保险从业资格CICE',
    'economic_analyst': '经济师',
    'taxation_practitioner': '税务师',
    'futures_qualification': '期货从业资格',
16
    'certified_fin_planner': '理财规划师',
17
    'actuary_fin_math': '精算师-金融数学',
18
19
20
}

financeIQ_subject_mapping = {
21
    '注册会计师(CPA)': '注册会计师(CPA)',
22
    '银行从业资格': '银行从业资格',
23
24
25
26
27
28
    '证券从业资格': '证券从业资格',
    '基金从业资格': '基金从业资格',
    '保险从业资格CICE': '保险从业资格CICE',
    '经济师': '经济师',
    '税务师': '税务师',
    '期货从业资格': '期货从业资格',
29
    '理财规划师': '理财规划师',
30
    '精算师-金融数学': '精算师-金融数学',
31
32
33
34
35
36
37
38
39
40
41
42
}

financeIQ_all_sets = list(financeIQ_subject_mapping.keys())

financeIQ_datasets = []
for _name in financeIQ_all_sets:
    _ch_name = financeIQ_subject_mapping[_name]
    financeIQ_infer_cfg = dict(
        ice_template=dict(
            type=PromptTemplate,
            template={
                answer: dict(
43
                    begin='</E>',
44
45
                    round=[
                        dict(
46
47
                            role='HUMAN',
                            prompt=f'以下是关于{_ch_name}的单项选择题,请直接给出正确答案的选项。\n题目:{{question}}\nA. {{A}}\nB. {{B}}\nC. {{C}}\nD. {{D}}'
48
                        ),
49
                        dict(role='BOT', prompt=f'答案是: {answer}'),
50
                    ])
51
                for answer in ['A', 'B', 'C', 'D']
52
            },
53
            ice_token='</E>',
54
55
56
57
58
59
60
61
62
63
        ),
        retriever=dict(type=FixKRetriever, fix_id_list=[0, 1, 2, 3, 4]),
        inferencer=dict(type=PPLInferencer),
    )

    financeIQ_eval_cfg = dict(evaluator=dict(type=AccEvaluator))

    financeIQ_datasets.append(
        dict(
            type=FinanceIQDataset,
64
            path='./data/FinanceIQ/',
65
            name=_name,
66
            abbr=f'FinanceIQ-{_name}',
67
            reader_cfg=dict(
68
69
70
                input_columns=['question', 'A', 'B', 'C', 'D'],
                output_column='answer',
                train_split='dev',
71
72
73
74
75
76
                test_split='test'),
            infer_cfg=financeIQ_infer_cfg,
            eval_cfg=financeIQ_eval_cfg,
        ))

del _name, _ch_name