2024-05-06 15:31:42 +08:00
|
|
|
from opencompass.openicl.icl_prompt_template import PromptTemplate
|
|
|
|
from opencompass.openicl.icl_retriever import ZeroRetriever
|
|
|
|
from opencompass.openicl.icl_inferencer import GenInferencer
|
|
|
|
from opencompass.openicl.icl_evaluator import AccEvaluator
|
|
|
|
from opencompass.datasets import AGIEvalDataset_v2, AGIEvalEvaluator
|
|
|
|
from opencompass.utils.text_postprocessors import first_option_postprocess, first_capital_postprocess_multi
|
|
|
|
|
|
|
|
agieval_reader_cfg = dict(
|
|
|
|
input_columns=['question', 'options'], output_column='label')
|
|
|
|
|
|
|
|
agieval_single_choice_sets = [
|
|
|
|
'gaokao-chinese',
|
|
|
|
'gaokao-english',
|
|
|
|
'gaokao-geography',
|
|
|
|
'gaokao-history',
|
|
|
|
'gaokao-biology',
|
|
|
|
'gaokao-chemistry',
|
|
|
|
'gaokao-mathqa',
|
|
|
|
'logiqa-zh',
|
|
|
|
'lsat-ar',
|
|
|
|
'lsat-lr',
|
|
|
|
'lsat-rc',
|
|
|
|
'logiqa-en',
|
|
|
|
'sat-math',
|
|
|
|
'sat-en',
|
|
|
|
'sat-en-without-passage',
|
|
|
|
'aqua-rat',
|
|
|
|
]
|
|
|
|
agieval_multiple_choices_sets = [
|
|
|
|
'gaokao-physics',
|
|
|
|
'jec-qa-kd',
|
|
|
|
'jec-qa-ca',
|
|
|
|
]
|
|
|
|
agieval_cloze_sets = ['gaokao-mathcloze', 'math']
|
|
|
|
agieval_chinese_sets = [
|
|
|
|
'gaokao-chinese',
|
|
|
|
'gaokao-english',
|
|
|
|
'gaokao-geography',
|
|
|
|
'gaokao-history',
|
|
|
|
'gaokao-biology',
|
|
|
|
'gaokao-chemistry',
|
|
|
|
'gaokao-physics',
|
|
|
|
'gaokao-mathqa',
|
|
|
|
'logiqa-zh',
|
|
|
|
'gaokao-mathcloze',
|
|
|
|
'jec-qa-kd',
|
|
|
|
'jec-qa-ca',
|
|
|
|
]
|
|
|
|
agieval_english_sets = [
|
|
|
|
'lsat-ar',
|
|
|
|
'lsat-lr',
|
|
|
|
'lsat-rc',
|
|
|
|
'logiqa-en',
|
|
|
|
'sat-math',
|
|
|
|
'sat-en',
|
|
|
|
'sat-en-without-passage',
|
|
|
|
'aqua-rat',
|
|
|
|
'math',
|
|
|
|
]
|
|
|
|
agieval_gaokao_sets = [
|
|
|
|
'gaokao-chinese',
|
|
|
|
'gaokao-english',
|
|
|
|
'gaokao-geography',
|
|
|
|
'gaokao-history',
|
|
|
|
'gaokao-biology',
|
|
|
|
'gaokao-chemistry',
|
|
|
|
'gaokao-physics',
|
|
|
|
'gaokao-mathqa',
|
|
|
|
]
|
|
|
|
|
|
|
|
agieval_datasets = []
|
|
|
|
for _name in agieval_single_choice_sets:
|
|
|
|
if _name in agieval_chinese_sets:
|
|
|
|
_hint = '答案是: '
|
|
|
|
else:
|
|
|
|
_hint = 'The answer is '
|
|
|
|
agieval_infer_cfg = dict(
|
|
|
|
prompt_template=dict(
|
|
|
|
type=PromptTemplate,
|
|
|
|
template=dict(round=[
|
|
|
|
dict(
|
|
|
|
role='HUMAN', prompt=f'{{question}}\n{{options}}\n{_hint}')
|
|
|
|
])),
|
|
|
|
retriever=dict(type=ZeroRetriever),
|
|
|
|
inferencer=dict(type=GenInferencer, max_out_len=1024))
|
|
|
|
|
|
|
|
agieval_eval_cfg = dict(
|
|
|
|
evaluator=dict(type=AccEvaluator),
|
|
|
|
pred_postprocessor=dict(
|
|
|
|
type=first_option_postprocess, options='ABCDE'))
|
|
|
|
|
|
|
|
agieval_datasets.append(
|
|
|
|
dict(
|
|
|
|
type=AGIEvalDataset_v2,
|
[Feature] Support ModelScope datasets (#1289)
* add ceval, gsm8k modelscope surpport
* update race, mmlu, arc, cmmlu, commonsenseqa, humaneval and unittest
* update bbh, flores, obqa, siqa, storycloze, summedits, winogrande, xsum datasets
* format file
* format file
* update dataset format
* support ms_dataset
* udpate dataset for modelscope support
* merge myl_dev and update test_ms_dataset
* udpate dataset for modelscope support
* update readme
* update eval_api_zhipu_v2
* remove unused code
* add get_data_path function
* update readme
* remove tydiqa japanese subset
* add ceval, gsm8k modelscope surpport
* update race, mmlu, arc, cmmlu, commonsenseqa, humaneval and unittest
* update bbh, flores, obqa, siqa, storycloze, summedits, winogrande, xsum datasets
* format file
* format file
* update dataset format
* support ms_dataset
* udpate dataset for modelscope support
* merge myl_dev and update test_ms_dataset
* update readme
* udpate dataset for modelscope support
* update eval_api_zhipu_v2
* remove unused code
* add get_data_path function
* remove tydiqa japanese subset
* update util
* remove .DS_Store
* fix md format
* move util into package
* update docs/get_started.md
* restore eval_api_zhipu_v2.py, add environment setting
* Update dataset
* Update
* Update
* Update
* Update
---------
Co-authored-by: Yun lin <yunlin@U-Q9X2K4QV-1904.local>
Co-authored-by: Yunnglin <mao.looper@qq.com>
Co-authored-by: Yun lin <yunlin@laptop.local>
Co-authored-by: Yunnglin <maoyl@smail.nju.edu.cn>
Co-authored-by: zhangsongyang <zhangsongyang@pjlab.org.cn>
2024-07-29 13:48:32 +08:00
|
|
|
path='opencompass/agieval',
|
2024-05-06 15:31:42 +08:00
|
|
|
name=_name,
|
|
|
|
abbr='agieval-' + _name,
|
|
|
|
setting_name='zero-shot',
|
|
|
|
reader_cfg=agieval_reader_cfg,
|
|
|
|
infer_cfg=agieval_infer_cfg.copy(),
|
|
|
|
eval_cfg=agieval_eval_cfg.copy()))
|
|
|
|
|
|
|
|
for _name in agieval_multiple_choices_sets:
|
|
|
|
if _name in agieval_chinese_sets:
|
|
|
|
_hint = '答案是: '
|
|
|
|
else:
|
|
|
|
_hint = 'The answer is '
|
|
|
|
agieval_infer_cfg = dict(
|
|
|
|
prompt_template=dict(
|
|
|
|
type=PromptTemplate,
|
|
|
|
template=dict(round=[
|
|
|
|
dict(
|
|
|
|
role='HUMAN', prompt=f'{{question}}\n{{options}}\n{_hint}')
|
|
|
|
])),
|
|
|
|
retriever=dict(type=ZeroRetriever),
|
|
|
|
inferencer=dict(type=GenInferencer, max_out_len=1024))
|
|
|
|
|
|
|
|
agieval_eval_cfg = dict(
|
|
|
|
evaluator=dict(type=AccEvaluator),
|
|
|
|
pred_postprocessor=dict(type=first_capital_postprocess_multi))
|
|
|
|
|
|
|
|
agieval_datasets.append(
|
|
|
|
dict(
|
|
|
|
type=AGIEvalDataset_v2,
|
[Feature] Support ModelScope datasets (#1289)
* add ceval, gsm8k modelscope surpport
* update race, mmlu, arc, cmmlu, commonsenseqa, humaneval and unittest
* update bbh, flores, obqa, siqa, storycloze, summedits, winogrande, xsum datasets
* format file
* format file
* update dataset format
* support ms_dataset
* udpate dataset for modelscope support
* merge myl_dev and update test_ms_dataset
* udpate dataset for modelscope support
* update readme
* update eval_api_zhipu_v2
* remove unused code
* add get_data_path function
* update readme
* remove tydiqa japanese subset
* add ceval, gsm8k modelscope surpport
* update race, mmlu, arc, cmmlu, commonsenseqa, humaneval and unittest
* update bbh, flores, obqa, siqa, storycloze, summedits, winogrande, xsum datasets
* format file
* format file
* update dataset format
* support ms_dataset
* udpate dataset for modelscope support
* merge myl_dev and update test_ms_dataset
* update readme
* udpate dataset for modelscope support
* update eval_api_zhipu_v2
* remove unused code
* add get_data_path function
* remove tydiqa japanese subset
* update util
* remove .DS_Store
* fix md format
* move util into package
* update docs/get_started.md
* restore eval_api_zhipu_v2.py, add environment setting
* Update dataset
* Update
* Update
* Update
* Update
---------
Co-authored-by: Yun lin <yunlin@U-Q9X2K4QV-1904.local>
Co-authored-by: Yunnglin <mao.looper@qq.com>
Co-authored-by: Yun lin <yunlin@laptop.local>
Co-authored-by: Yunnglin <maoyl@smail.nju.edu.cn>
Co-authored-by: zhangsongyang <zhangsongyang@pjlab.org.cn>
2024-07-29 13:48:32 +08:00
|
|
|
path='opencompass/agieval',
|
2024-05-06 15:31:42 +08:00
|
|
|
name=_name,
|
|
|
|
abbr='agieval-' + _name,
|
|
|
|
setting_name='zero-shot',
|
|
|
|
reader_cfg=agieval_reader_cfg,
|
|
|
|
infer_cfg=agieval_infer_cfg.copy(),
|
|
|
|
eval_cfg=agieval_eval_cfg.copy()))
|
|
|
|
|
|
|
|
for _name in agieval_cloze_sets:
|
|
|
|
if _name in agieval_chinese_sets:
|
|
|
|
_hint = '答案是: '
|
|
|
|
else:
|
|
|
|
_hint = 'The answer is '
|
|
|
|
agieval_infer_cfg = dict(
|
|
|
|
prompt_template=dict(
|
|
|
|
type=PromptTemplate,
|
|
|
|
template=dict(
|
|
|
|
round=[dict(role='HUMAN', prompt=f'{{question}}\n{_hint}')])),
|
|
|
|
retriever=dict(type=ZeroRetriever),
|
|
|
|
inferencer=dict(type=GenInferencer, max_out_len=1024))
|
|
|
|
|
|
|
|
agieval_eval_cfg = dict(evaluator=dict(type=AGIEvalEvaluator))
|
|
|
|
|
|
|
|
agieval_datasets.append(
|
|
|
|
dict(
|
|
|
|
type=AGIEvalDataset_v2,
|
[Feature] Support ModelScope datasets (#1289)
* add ceval, gsm8k modelscope surpport
* update race, mmlu, arc, cmmlu, commonsenseqa, humaneval and unittest
* update bbh, flores, obqa, siqa, storycloze, summedits, winogrande, xsum datasets
* format file
* format file
* update dataset format
* support ms_dataset
* udpate dataset for modelscope support
* merge myl_dev and update test_ms_dataset
* udpate dataset for modelscope support
* update readme
* update eval_api_zhipu_v2
* remove unused code
* add get_data_path function
* update readme
* remove tydiqa japanese subset
* add ceval, gsm8k modelscope surpport
* update race, mmlu, arc, cmmlu, commonsenseqa, humaneval and unittest
* update bbh, flores, obqa, siqa, storycloze, summedits, winogrande, xsum datasets
* format file
* format file
* update dataset format
* support ms_dataset
* udpate dataset for modelscope support
* merge myl_dev and update test_ms_dataset
* update readme
* udpate dataset for modelscope support
* update eval_api_zhipu_v2
* remove unused code
* add get_data_path function
* remove tydiqa japanese subset
* update util
* remove .DS_Store
* fix md format
* move util into package
* update docs/get_started.md
* restore eval_api_zhipu_v2.py, add environment setting
* Update dataset
* Update
* Update
* Update
* Update
---------
Co-authored-by: Yun lin <yunlin@U-Q9X2K4QV-1904.local>
Co-authored-by: Yunnglin <mao.looper@qq.com>
Co-authored-by: Yun lin <yunlin@laptop.local>
Co-authored-by: Yunnglin <maoyl@smail.nju.edu.cn>
Co-authored-by: zhangsongyang <zhangsongyang@pjlab.org.cn>
2024-07-29 13:48:32 +08:00
|
|
|
path='opencompass/agieval',
|
2024-05-06 15:31:42 +08:00
|
|
|
name=_name,
|
|
|
|
abbr='agieval-' + _name,
|
|
|
|
setting_name='zero-shot',
|
|
|
|
reader_cfg=agieval_reader_cfg,
|
|
|
|
infer_cfg=agieval_infer_cfg.copy(),
|
|
|
|
eval_cfg=agieval_eval_cfg.copy()))
|
|
|
|
|
|
|
|
for _item in agieval_datasets:
|
|
|
|
_name = _item['name']
|
|
|
|
_intro = {
|
|
|
|
'gaokao-chinese':
|
|
|
|
'以下是一道中国高考语文选择题,请选择正确的答案。',
|
|
|
|
'gaokao-english':
|
|
|
|
'以下是一道中国高考英语选择题,请选择正确的答案。',
|
|
|
|
'gaokao-geography':
|
|
|
|
'以下是一道中国高考地理选择题,请选择正确的答案。',
|
|
|
|
'gaokao-history':
|
|
|
|
'以下是一道中国高考历史选择题,请选择正确的答案。',
|
|
|
|
'gaokao-biology':
|
|
|
|
'以下是一道中国高考生物选择题,请选择正确的答案。',
|
|
|
|
'gaokao-chemistry':
|
|
|
|
'以下是一道中国高考化学选择题,请选择正确的答案。',
|
|
|
|
'gaokao-physics':
|
|
|
|
'以下是一道中国高考物理选择题,请选择正确的答案。',
|
|
|
|
'gaokao-mathqa':
|
|
|
|
'以下是一道中国高考数学选择题,请选择正确的答案。',
|
|
|
|
'logiqa-zh':
|
|
|
|
'以下是一道中国公务员考试题,请选择正确的答案。',
|
|
|
|
'lsat-ar':
|
|
|
|
'The following is a LSAT Analytical Reasoning question. Please select the correct answer.',
|
|
|
|
'lsat-lr':
|
|
|
|
'The following is a LSAT Logical Reasoning question. Please select the correct answer.',
|
|
|
|
'lsat-rc':
|
|
|
|
'The following is a LSAT Reading Comprehension question. Please select the correct answer.',
|
|
|
|
'logiqa-en':
|
|
|
|
'The following is a Logic Reasoning question. Please select the correct answer.',
|
|
|
|
'sat-math':
|
|
|
|
'The following is a SAT Math question. Please select the correct answer.',
|
|
|
|
'sat-en':
|
|
|
|
'The following is a SAT English question. Please select the correct answer.',
|
|
|
|
'sat-en-without-passage':
|
|
|
|
'The following is a SAT English question. Please select the correct answer.',
|
|
|
|
'aqua-rat':
|
|
|
|
'The following is a AQUA-RAT question. Please select the correct answer.',
|
|
|
|
'jec-qa-kd':
|
|
|
|
'以下是一道中国司法考试基础知识题,请选择正确的答案。',
|
|
|
|
'jec-qa-ca':
|
|
|
|
'以下是一道中国司法考试案例分析题,请选择正确的答案。',
|
|
|
|
'gaokao-mathcloze':
|
|
|
|
'以下是一道中国高考数学填空题,请填入正确的答案。',
|
|
|
|
'math':
|
|
|
|
'The following is a Math question. Please select the correct answer.',
|
|
|
|
}[_name]
|
|
|
|
_templates = _item['infer_cfg']['prompt_template']['template']
|
|
|
|
_templates['round'][0][
|
|
|
|
'prompt'] = _intro + '\n' + _templates['round'][0]['prompt']
|
|
|
|
|
|
|
|
del _item, _intro, _templates, _name, _hint, agieval_infer_cfg, agieval_eval_cfg
|