evalscope 0.10.0__py3-none-any.whl → 1.2.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- evalscope/__init__.py +4 -1
- evalscope/api/benchmark/__init__.py +11 -0
- evalscope/api/benchmark/adapters/__init__.py +7 -0
- evalscope/api/benchmark/adapters/agent_adapter.py +8 -0
- evalscope/api/benchmark/adapters/default_data_adapter.py +754 -0
- evalscope/api/benchmark/adapters/image_edit_adapter.py +82 -0
- evalscope/api/benchmark/adapters/multi_choice_adapter.py +86 -0
- evalscope/api/benchmark/adapters/ner_adapter.py +212 -0
- evalscope/api/benchmark/adapters/text2image_adapter.py +157 -0
- evalscope/api/benchmark/adapters/vision_language_adapter.py +8 -0
- evalscope/api/benchmark/benchmark.py +404 -0
- evalscope/api/benchmark/meta.py +124 -0
- evalscope/api/dataset/__init__.py +2 -0
- evalscope/api/dataset/dataset.py +370 -0
- evalscope/api/dataset/loader.py +266 -0
- evalscope/api/dataset/utils.py +143 -0
- evalscope/api/evaluator/__init__.py +3 -0
- evalscope/api/evaluator/cache.py +382 -0
- evalscope/api/evaluator/evaluator.py +61 -0
- evalscope/api/evaluator/state.py +280 -0
- evalscope/api/filter/__init__.py +1 -0
- evalscope/api/filter/filter.py +72 -0
- evalscope/api/messages/__init__.py +12 -0
- evalscope/api/messages/chat_message.py +248 -0
- evalscope/api/messages/content.py +102 -0
- evalscope/api/messages/utils.py +35 -0
- evalscope/api/metric/__init__.py +2 -0
- evalscope/api/metric/metric.py +60 -0
- evalscope/api/metric/scorer.py +113 -0
- evalscope/api/mixin/__init__.py +2 -0
- evalscope/api/mixin/llm_judge_mixin.py +170 -0
- evalscope/api/mixin/sandbox_mixin.py +182 -0
- evalscope/api/model/__init__.py +12 -0
- evalscope/api/model/generate_config.py +161 -0
- evalscope/api/model/model.py +386 -0
- evalscope/api/model/model_output.py +285 -0
- evalscope/api/registry.py +182 -0
- evalscope/api/tool/__init__.py +3 -0
- evalscope/api/tool/tool_call.py +101 -0
- evalscope/api/tool/tool_info.py +173 -0
- evalscope/api/tool/utils.py +64 -0
- evalscope/app/__init__.py +28 -0
- evalscope/app/app.py +38 -0
- evalscope/app/arguments.py +11 -0
- evalscope/app/constants.py +22 -0
- evalscope/app/ui/__init__.py +20 -0
- evalscope/app/ui/app_ui.py +53 -0
- evalscope/app/ui/multi_model.py +353 -0
- evalscope/app/ui/sidebar.py +42 -0
- evalscope/app/ui/single_model.py +220 -0
- evalscope/app/ui/visualization.py +36 -0
- evalscope/app/utils/data_utils.py +195 -0
- evalscope/app/utils/env_utils.py +12 -0
- evalscope/app/utils/localization.py +221 -0
- evalscope/app/utils/text_utils.py +119 -0
- evalscope/app/utils/visualization.py +96 -0
- evalscope/arguments.py +32 -9
- evalscope/backend/opencompass/api_meta_template.py +2 -1
- evalscope/backend/opencompass/backend_manager.py +10 -7
- evalscope/backend/rag_eval/__init__.py +1 -1
- evalscope/backend/rag_eval/backend_manager.py +23 -6
- evalscope/backend/rag_eval/clip_benchmark/dataset_builder.py +33 -21
- evalscope/backend/rag_eval/clip_benchmark/task_template.py +8 -4
- evalscope/backend/rag_eval/cmteb/arguments.py +14 -1
- evalscope/backend/rag_eval/cmteb/task_template.py +19 -3
- evalscope/backend/rag_eval/cmteb/tasks/CustomTask.py +1 -1
- evalscope/backend/rag_eval/ragas/arguments.py +0 -1
- evalscope/backend/rag_eval/ragas/task_template.py +2 -1
- evalscope/backend/rag_eval/ragas/tasks/build_distribution.py +2 -1
- evalscope/backend/rag_eval/ragas/tasks/build_transform.py +7 -4
- evalscope/backend/rag_eval/ragas/tasks/testset_generation.py +9 -3
- evalscope/backend/rag_eval/ragas/tasks/translate_prompt.py +2 -6
- evalscope/backend/rag_eval/utils/embedding.py +125 -32
- evalscope/backend/rag_eval/utils/llm.py +16 -16
- evalscope/backend/vlm_eval_kit/backend_manager.py +8 -3
- evalscope/benchmarks/__init__.py +17 -5
- evalscope/benchmarks/aa_lcr/__init__.py +0 -0
- evalscope/benchmarks/aa_lcr/aa_lcr_adapter.py +205 -0
- evalscope/benchmarks/ai2d/__init__.py +0 -0
- evalscope/benchmarks/ai2d/ai2d_adapter.py +54 -0
- evalscope/benchmarks/aime/__init__.py +0 -0
- evalscope/benchmarks/aime/aime24_adapter.py +55 -0
- evalscope/benchmarks/aime/aime25_adapter.py +181 -0
- evalscope/benchmarks/aime/grader.py +307 -0
- evalscope/{metrics/math_accuracy.py → benchmarks/aime/math_normalize.py} +61 -72
- evalscope/benchmarks/alpaca_eval/__init__.py +0 -0
- evalscope/benchmarks/alpaca_eval/alpaca_eval_adapter.py +133 -0
- evalscope/benchmarks/amc/__init__.py +0 -0
- evalscope/benchmarks/amc/amc_adapter.py +51 -0
- evalscope/benchmarks/arc/arc_adapter.py +34 -149
- evalscope/benchmarks/arena_hard/__init__.py +0 -0
- evalscope/benchmarks/arena_hard/arena_hard_adapter.py +149 -0
- evalscope/benchmarks/arena_hard/utils.py +186 -0
- evalscope/benchmarks/bbh/bbh_adapter.py +117 -157
- evalscope/benchmarks/bfcl/__init__.py +0 -0
- evalscope/benchmarks/bfcl/v3/__init__.py +0 -0
- evalscope/benchmarks/bfcl/v3/bfcl_v3_adapter.py +370 -0
- evalscope/benchmarks/bfcl/v3/generation.py +222 -0
- evalscope/benchmarks/bfcl/v3/utils.py +23 -0
- evalscope/benchmarks/bfcl/v4/__init__.py +0 -0
- evalscope/benchmarks/bfcl/v4/bfcl_v4_adapter.py +229 -0
- evalscope/benchmarks/bfcl/v4/utils.py +410 -0
- evalscope/benchmarks/biomix_qa/__init__.py +0 -0
- evalscope/benchmarks/biomix_qa/biomix_qa_adapter.py +36 -0
- evalscope/benchmarks/blink/__init__.py +0 -0
- evalscope/benchmarks/blink/blink_adapter.py +61 -0
- evalscope/benchmarks/ceval/ceval_adapter.py +93 -174
- evalscope/benchmarks/chartqa/__init__.py +0 -0
- evalscope/benchmarks/chartqa/chartqa_adapter.py +80 -0
- evalscope/benchmarks/chartqa/utils.py +38 -0
- evalscope/benchmarks/chinese_simple_qa/__init__.py +0 -0
- evalscope/benchmarks/chinese_simple_qa/csimple_qa_adapter.py +170 -0
- evalscope/benchmarks/cmmlu/cmmlu_adapter.py +34 -140
- evalscope/benchmarks/coin_flip/__init__.py +0 -0
- evalscope/benchmarks/coin_flip/coin_flip_adapter.py +128 -0
- evalscope/benchmarks/commonsense_qa/__init__.py +0 -0
- evalscope/benchmarks/commonsense_qa/commonsense_qa_adapter.py +32 -0
- evalscope/benchmarks/competition_math/competition_math_adapter.py +64 -112
- evalscope/benchmarks/data_collection/__init__.py +0 -0
- evalscope/benchmarks/data_collection/data_collection_adapter.py +215 -0
- evalscope/benchmarks/docmath/__init__.py +0 -0
- evalscope/benchmarks/docmath/docmath_adapter.py +143 -0
- evalscope/benchmarks/docmath/utils.py +219 -0
- evalscope/benchmarks/docvqa/__init__.py +0 -0
- evalscope/benchmarks/docvqa/docvqa_adapter.py +67 -0
- evalscope/benchmarks/drivelology/__init__.py +0 -0
- evalscope/benchmarks/drivelology/drivelology_binary_adapter.py +170 -0
- evalscope/benchmarks/drivelology/drivelology_multilabel_adapter.py +254 -0
- evalscope/benchmarks/drivelology/drivelology_selection_adapter.py +49 -0
- evalscope/benchmarks/drivelology/drivelology_writing_adapter.py +218 -0
- evalscope/benchmarks/drop/__init__.py +0 -0
- evalscope/benchmarks/drop/drop_adapter.py +155 -0
- evalscope/benchmarks/drop/utils.py +156 -0
- evalscope/benchmarks/frames/__init__.py +0 -0
- evalscope/benchmarks/frames/frames_adapter.py +175 -0
- evalscope/benchmarks/frames/utils.py +37 -0
- evalscope/benchmarks/general_arena/__init__.py +0 -0
- evalscope/benchmarks/general_arena/general_arena_adapter.py +454 -0
- evalscope/benchmarks/general_arena/utils.py +223 -0
- evalscope/benchmarks/general_mcq/__init__.py +0 -0
- evalscope/benchmarks/general_mcq/general_mcq_adapter.py +58 -0
- evalscope/benchmarks/general_qa/general_qa_adapter.py +75 -107
- evalscope/benchmarks/gpqa/__init__.py +0 -0
- evalscope/benchmarks/gpqa/gpqa_adapter.py +90 -0
- evalscope/benchmarks/gpqa/prompt.py +88 -0
- evalscope/benchmarks/gsm8k/gsm8k_adapter.py +77 -144
- evalscope/benchmarks/hallusion_bench/__init__.py +0 -0
- evalscope/benchmarks/hallusion_bench/hallusion_bench_adapter.py +159 -0
- evalscope/benchmarks/halu_eval/__init__.py +0 -0
- evalscope/benchmarks/halu_eval/halu_eval_adapter.py +128 -0
- evalscope/benchmarks/halu_eval/halu_eval_instructions.py +84 -0
- evalscope/benchmarks/healthbench/__init__.py +0 -0
- evalscope/benchmarks/healthbench/healthbench_adapter.py +282 -0
- evalscope/benchmarks/healthbench/utils.py +102 -0
- evalscope/benchmarks/hellaswag/hellaswag_adapter.py +36 -134
- evalscope/benchmarks/hle/__init__.py +0 -0
- evalscope/benchmarks/hle/hle_adapter.py +153 -0
- evalscope/benchmarks/humaneval/humaneval_adapter.py +80 -88
- evalscope/benchmarks/humaneval/utils.py +235 -0
- evalscope/benchmarks/ifeval/ifeval_adapter.py +71 -45
- evalscope/benchmarks/ifeval/instructions.py +112 -68
- evalscope/benchmarks/ifeval/instructions_registry.py +1 -1
- evalscope/benchmarks/ifeval/instructions_util.py +2 -3
- evalscope/benchmarks/ifeval/utils.py +6 -7
- evalscope/benchmarks/image_edit/__init__.py +0 -0
- evalscope/benchmarks/image_edit/gedit/__init__.py +0 -0
- evalscope/benchmarks/image_edit/gedit/gedit_adapter.py +138 -0
- evalscope/benchmarks/image_edit/gedit/utils.py +372 -0
- evalscope/benchmarks/image_edit/gedit/vie_prompts.py +406 -0
- evalscope/benchmarks/infovqa/__init__.py +0 -0
- evalscope/benchmarks/infovqa/infovqa_adapter.py +66 -0
- evalscope/benchmarks/iquiz/iquiz_adapter.py +30 -58
- evalscope/benchmarks/live_code_bench/__init__.py +0 -0
- evalscope/benchmarks/live_code_bench/evaluate_utils.py +195 -0
- evalscope/benchmarks/live_code_bench/extract_utils.py +70 -0
- evalscope/benchmarks/live_code_bench/live_code_bench_adapter.py +150 -0
- evalscope/benchmarks/live_code_bench/load_utils.py +63 -0
- evalscope/benchmarks/live_code_bench/pass_k_utils.py +56 -0
- evalscope/benchmarks/live_code_bench/prompts.py +207 -0
- evalscope/benchmarks/live_code_bench/sandbox_evaluate_utils.py +220 -0
- evalscope/benchmarks/live_code_bench/testing_util.py +544 -0
- evalscope/benchmarks/logi_qa/__int__.py +0 -0
- evalscope/benchmarks/logi_qa/logi_qa_adapter.py +41 -0
- evalscope/benchmarks/maritime_bench/__init__.py +0 -0
- evalscope/benchmarks/maritime_bench/maritime_bench_adapter.py +56 -0
- evalscope/benchmarks/math_500/__init__.py +0 -0
- evalscope/benchmarks/math_500/math_500_adapter.py +55 -0
- evalscope/benchmarks/math_qa/__init__.py +0 -0
- evalscope/benchmarks/math_qa/math_qa_adapter.py +35 -0
- evalscope/benchmarks/math_verse/__init__.py +0 -0
- evalscope/benchmarks/math_verse/math_verse_adapter.py +105 -0
- evalscope/benchmarks/math_vision/__init__.py +0 -0
- evalscope/benchmarks/math_vision/math_vision_adapter.py +116 -0
- evalscope/benchmarks/math_vista/__init__.py +0 -0
- evalscope/benchmarks/math_vista/math_vista_adapter.py +114 -0
- evalscope/benchmarks/med_mcqa/__init__.py +0 -0
- evalscope/benchmarks/med_mcqa/med_mcqa_adapter.py +32 -0
- evalscope/benchmarks/minerva_math/__init__.py +0 -0
- evalscope/benchmarks/minerva_math/minerva_math_adapter.py +53 -0
- evalscope/benchmarks/mm_bench/__init__.py +0 -0
- evalscope/benchmarks/mm_bench/mm_bench_adapter.py +99 -0
- evalscope/benchmarks/mm_star/__init__.py +0 -0
- evalscope/benchmarks/mm_star/mm_star_adapter.py +73 -0
- evalscope/benchmarks/mmlu/mmlu_adapter.py +32 -210
- evalscope/benchmarks/mmlu_pro/mmlu_pro_adapter.py +87 -103
- evalscope/benchmarks/mmlu_redux/__init__.py +0 -0
- evalscope/benchmarks/mmlu_redux/mmlu_redux_adapter.py +139 -0
- evalscope/benchmarks/mmmu/__init__.py +0 -0
- evalscope/benchmarks/mmmu/mmmu_adapter.py +159 -0
- evalscope/benchmarks/mmmu_pro/__init__.py +0 -0
- evalscope/benchmarks/mmmu_pro/mmmu_pro_adapter.py +124 -0
- evalscope/benchmarks/mri_mcqa/__init__.py +0 -0
- evalscope/benchmarks/mri_mcqa/mri_mcqa_adapter.py +34 -0
- evalscope/benchmarks/multi_if/__init__.py +0 -0
- evalscope/benchmarks/multi_if/ifeval.py +3354 -0
- evalscope/benchmarks/multi_if/metrics.py +120 -0
- evalscope/benchmarks/multi_if/multi_if_adapter.py +161 -0
- evalscope/benchmarks/music_trivia/__init__.py +0 -0
- evalscope/benchmarks/music_trivia/music_trivia_adapter.py +36 -0
- evalscope/benchmarks/musr/__init__.py +0 -0
- evalscope/benchmarks/musr/musr_adapter.py +43 -0
- evalscope/benchmarks/needle_haystack/__init__.py +0 -0
- evalscope/benchmarks/needle_haystack/needle_haystack_adapter.py +389 -0
- evalscope/benchmarks/needle_haystack/utils.py +79 -0
- evalscope/benchmarks/ner/__init__.py +0 -0
- evalscope/benchmarks/ner/broad_twitter_corpus_adapter.py +52 -0
- evalscope/benchmarks/ner/conll2003_adapter.py +48 -0
- evalscope/benchmarks/ner/copious_adapter.py +85 -0
- evalscope/benchmarks/ner/cross_ner_adapter.py +120 -0
- evalscope/benchmarks/ner/cross_ner_entities/__init__.py +0 -0
- evalscope/benchmarks/ner/cross_ner_entities/ai.py +54 -0
- evalscope/benchmarks/ner/cross_ner_entities/literature.py +36 -0
- evalscope/benchmarks/ner/cross_ner_entities/music.py +39 -0
- evalscope/benchmarks/ner/cross_ner_entities/politics.py +37 -0
- evalscope/benchmarks/ner/cross_ner_entities/science.py +58 -0
- evalscope/benchmarks/ner/genia_ner_adapter.py +66 -0
- evalscope/benchmarks/ner/harvey_ner_adapter.py +58 -0
- evalscope/benchmarks/ner/mit_movie_trivia_adapter.py +74 -0
- evalscope/benchmarks/ner/mit_restaurant_adapter.py +66 -0
- evalscope/benchmarks/ner/ontonotes5_adapter.py +87 -0
- evalscope/benchmarks/ner/wnut2017_adapter.py +61 -0
- evalscope/benchmarks/ocr_bench/__init__.py +0 -0
- evalscope/benchmarks/ocr_bench/ocr_bench/__init__.py +0 -0
- evalscope/benchmarks/ocr_bench/ocr_bench/ocr_bench_adapter.py +101 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/IoUscore_metric.py +87 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/TEDS_metric.py +963 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/__init__.py +0 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/ocr_bench_v2_adapter.py +161 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/page_ocr_metric.py +50 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/parallel.py +46 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/spotting_eval/__init__.py +0 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/spotting_eval/readme.txt +26 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/spotting_eval/rrc_evaluation_funcs_1_1.py +537 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/spotting_eval/script.py +481 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/spotting_metric.py +179 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/utils.py +433 -0
- evalscope/benchmarks/ocr_bench/ocr_bench_v2/vqa_metric.py +254 -0
- evalscope/benchmarks/olympiad_bench/__init__.py +0 -0
- evalscope/benchmarks/olympiad_bench/olympiad_bench_adapter.py +163 -0
- evalscope/benchmarks/olympiad_bench/utils.py +565 -0
- evalscope/benchmarks/omni_bench/__init__.py +0 -0
- evalscope/benchmarks/omni_bench/omni_bench_adapter.py +86 -0
- evalscope/benchmarks/omnidoc_bench/__init__.py +0 -0
- evalscope/benchmarks/omnidoc_bench/end2end_eval.py +349 -0
- evalscope/benchmarks/omnidoc_bench/metrics.py +547 -0
- evalscope/benchmarks/omnidoc_bench/omnidoc_bench_adapter.py +135 -0
- evalscope/benchmarks/omnidoc_bench/utils.py +1937 -0
- evalscope/benchmarks/piqa/__init__.py +0 -0
- evalscope/benchmarks/piqa/piqa_adapter.py +32 -0
- evalscope/benchmarks/poly_math/__init__.py +0 -0
- evalscope/benchmarks/poly_math/poly_math_adapter.py +132 -0
- evalscope/benchmarks/poly_math/utils/instruction.py +105 -0
- evalscope/benchmarks/pope/__init__.py +0 -0
- evalscope/benchmarks/pope/pope_adapter.py +112 -0
- evalscope/benchmarks/process_bench/__init__.py +0 -0
- evalscope/benchmarks/process_bench/process_bench_adapter.py +171 -0
- evalscope/benchmarks/pumed_qa/__init__.py +0 -0
- evalscope/benchmarks/pumed_qa/pubmed_qa_adapter.py +175 -0
- evalscope/benchmarks/qasc/__init__.py +0 -0
- evalscope/benchmarks/qasc/qasc_adapter.py +35 -0
- evalscope/benchmarks/race/race_adapter.py +33 -120
- evalscope/benchmarks/real_world_qa/__init__.py +0 -0
- evalscope/benchmarks/real_world_qa/real_world_qa_adapter.py +64 -0
- evalscope/benchmarks/sciq/__init__.py +0 -0
- evalscope/benchmarks/sciq/sciq_adapter.py +36 -0
- evalscope/benchmarks/seed_bench_2_plus/__init__.py +0 -0
- evalscope/benchmarks/seed_bench_2_plus/seed_bench_2_plus_adapter.py +72 -0
- evalscope/benchmarks/simple_qa/__init__.py +0 -0
- evalscope/benchmarks/simple_qa/simple_qa_adapter.py +169 -0
- evalscope/benchmarks/simple_vqa/__init__.py +0 -0
- evalscope/benchmarks/simple_vqa/simple_vqa_adapter.py +169 -0
- evalscope/benchmarks/siqa/__init__.py +0 -0
- evalscope/benchmarks/siqa/siqa_adapter.py +39 -0
- evalscope/benchmarks/super_gpqa/__init__.py +0 -0
- evalscope/benchmarks/super_gpqa/prompt.py +88 -0
- evalscope/benchmarks/super_gpqa/super_gpqa_adapter.py +165 -0
- evalscope/benchmarks/super_gpqa/utils.py +86 -0
- evalscope/benchmarks/tau_bench/__init__.py +0 -0
- evalscope/benchmarks/tau_bench/tau2_bench/__init__.py +0 -0
- evalscope/benchmarks/tau_bench/tau2_bench/generation.py +158 -0
- evalscope/benchmarks/tau_bench/tau2_bench/tau2_bench_adapter.py +146 -0
- evalscope/benchmarks/tau_bench/tau_bench/__init__.py +0 -0
- evalscope/benchmarks/tau_bench/tau_bench/generation.py +147 -0
- evalscope/benchmarks/tau_bench/tau_bench/tau_bench_adapter.py +168 -0
- evalscope/benchmarks/text2image/__init__.py +0 -0
- evalscope/benchmarks/text2image/evalmuse_adapter.py +78 -0
- evalscope/benchmarks/text2image/genai_bench_adapter.py +53 -0
- evalscope/benchmarks/text2image/general_t2i_adapter.py +42 -0
- evalscope/benchmarks/text2image/hpdv2_adapter.py +52 -0
- evalscope/benchmarks/text2image/tifa_adapter.py +27 -0
- evalscope/benchmarks/tool_bench/__init__.py +0 -0
- evalscope/benchmarks/tool_bench/tool_bench_adapter.py +102 -0
- evalscope/benchmarks/tool_bench/utils.py +203 -0
- evalscope/benchmarks/trivia_qa/trivia_qa_adapter.py +56 -118
- evalscope/benchmarks/truthful_qa/truthful_qa_adapter.py +70 -270
- evalscope/benchmarks/visu_logic/__init__.py +0 -0
- evalscope/benchmarks/visu_logic/visu_logic_adapter.py +75 -0
- evalscope/benchmarks/winogrande/__init__.py +0 -0
- evalscope/benchmarks/winogrande/winogrande_adapter.py +34 -0
- evalscope/benchmarks/wmt/__init__.py +0 -0
- evalscope/benchmarks/wmt/wmt24_adapter.py +294 -0
- evalscope/benchmarks/zerobench/__init__.py +0 -0
- evalscope/benchmarks/zerobench/zerobench_adapter.py +64 -0
- evalscope/cli/cli.py +2 -0
- evalscope/cli/start_app.py +12 -2
- evalscope/cli/start_eval.py +4 -3
- evalscope/cli/start_perf.py +10 -2
- evalscope/cli/start_server.py +6 -3
- evalscope/collections/__init__.py +27 -3
- evalscope/collections/sampler.py +12 -11
- evalscope/collections/schema.py +13 -12
- evalscope/config.py +218 -147
- evalscope/constants.py +78 -82
- evalscope/evaluator/__init__.py +1 -1
- evalscope/evaluator/evaluator.py +334 -318
- evalscope/filters/__init__.py +2 -0
- evalscope/filters/extraction.py +126 -0
- evalscope/filters/selection.py +57 -0
- evalscope/metrics/__init__.py +59 -3
- evalscope/metrics/bert_score/__init__.py +0 -0
- evalscope/metrics/bert_score/scorer.py +338 -0
- evalscope/metrics/bert_score/utils.py +697 -0
- evalscope/metrics/bundled_rouge_score/rouge_scorer.py +20 -15
- evalscope/metrics/llm_judge.py +211 -0
- evalscope/metrics/math_parser.py +545 -0
- evalscope/metrics/metric.py +611 -0
- evalscope/metrics/metrics.py +112 -23
- evalscope/metrics/rouge_metric.py +11 -13
- evalscope/metrics/t2v_metrics/__init__.py +0 -0
- evalscope/metrics/t2v_metrics/clipscore.py +14 -0
- evalscope/metrics/t2v_metrics/constants.py +12 -0
- evalscope/metrics/t2v_metrics/itmscore.py +14 -0
- evalscope/metrics/t2v_metrics/models/__init__.py +0 -0
- evalscope/metrics/t2v_metrics/models/clipscore_models/__init__.py +30 -0
- evalscope/metrics/t2v_metrics/models/clipscore_models/build_mps_model/__init__.py +0 -0
- evalscope/metrics/t2v_metrics/models/clipscore_models/build_mps_model/base_model.py +6 -0
- evalscope/metrics/t2v_metrics/models/clipscore_models/build_mps_model/clip_model.py +134 -0
- evalscope/metrics/t2v_metrics/models/clipscore_models/build_mps_model/cross_modeling.py +282 -0
- evalscope/metrics/t2v_metrics/models/clipscore_models/clip_model.py +115 -0
- evalscope/metrics/t2v_metrics/models/clipscore_models/hpsv2_model.py +87 -0
- evalscope/metrics/t2v_metrics/models/clipscore_models/mps_model.py +86 -0
- evalscope/metrics/t2v_metrics/models/clipscore_models/pickscore_model.py +62 -0
- evalscope/metrics/t2v_metrics/models/itmscore_models/__init__.py +26 -0
- evalscope/metrics/t2v_metrics/models/itmscore_models/blip2_itm_model.py +85 -0
- evalscope/metrics/t2v_metrics/models/itmscore_models/fga_blip2_model.py +99 -0
- evalscope/metrics/t2v_metrics/models/itmscore_models/image_reward/ImageReward.py +176 -0
- evalscope/metrics/t2v_metrics/models/itmscore_models/image_reward/__init__.py +0 -0
- evalscope/metrics/t2v_metrics/models/itmscore_models/image_reward/blip_pretrain.py +82 -0
- evalscope/metrics/t2v_metrics/models/itmscore_models/image_reward_model.py +74 -0
- evalscope/metrics/t2v_metrics/models/model.py +45 -0
- evalscope/metrics/t2v_metrics/models/utils.py +25 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/__init__.py +22 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/clip_t5/__init__.py +0 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/clip_t5/model/__init__.py +1 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/clip_t5/model/language_model/clip_t5.py +306 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/clip_t5/model/multimodal_encoder/builder.py +12 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/clip_t5/model/multimodal_encoder/clip_encoder.py +84 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/clip_t5/model/multimodal_projector/builder.py +50 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/clip_t5_model.py +223 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/gpt4v_model.py +153 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/__init__.py +26 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/common/config.py +465 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/common/dist_utils.py +141 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/common/gradcam.py +24 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/common/logger.py +190 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/common/optims.py +100 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/common/registry.py +313 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/common/utils.py +416 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/common/vqa_tools/__init__.py +8 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/common/vqa_tools/vqa.py +192 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/common/vqa_tools/vqa_eval.py +320 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/default.yaml +10 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_caption_flant5xl.yaml +42 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_caption_opt2.7b.yaml +42 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_caption_opt6.7b.yaml +42 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_coco.yaml +36 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_instruct_flant5xl.yaml +43 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_instruct_flant5xxl.yaml +43 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_instruct_vicuna13b.yaml +43 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_instruct_vicuna7b.yaml +43 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_pretrain.yaml +36 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_pretrain_flant5xl.yaml +42 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_pretrain_flant5xl_iter_80k_total_100k_no_prefix.yaml +42 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_pretrain_flant5xl_iter_80k_total_100k_prefix.yaml +42 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_pretrain_flant5xl_vitL.yaml +43 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_pretrain_flant5xxl.yaml +42 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_pretrain_opt2.7b.yaml +42 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_pretrain_opt6.7b.yaml +42 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_pretrain_vitL.yaml +37 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_vicuna13b.yaml +43 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/blip2/blip2_vicuna7b.yaml +43 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/med_config.json +21 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/med_config_albef.json +22 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/configs/models/med_large_config.json +21 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/__init__.py +212 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/base_model.py +231 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip2_models/Qformer.py +1111 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip2_models/__init__.py +0 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip2_models/blip2.py +211 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip2_models/blip2_image_text_matching.py +109 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip2_models/blip2_qformer.py +457 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip2_models/blip2_t5.py +370 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip2_models/blip2_t5_instruct.py +765 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip2_models/fga_blip2.py +274 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip2_models/modeling_llama.py +896 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip2_models/modeling_t5.py +1876 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip_models/__init__.py +83 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip_models/blip.py +58 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip_models/blip_caption.py +212 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip_models/blip_classification.py +164 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip_models/blip_feature_extractor.py +202 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip_models/blip_image_text_matching.py +187 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip_models/blip_nlvr.py +179 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip_models/blip_outputs.py +115 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip_models/blip_pretrain.py +371 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip_models/blip_vqa.py +348 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/blip_models/nlvr_encoder.py +870 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/clip_vit.py +273 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/eva_vit.py +514 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/med.py +1291 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/models/vit.py +476 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/processors/__init__.py +35 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/processors/base_processor.py +27 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/processors/blip_processors.py +233 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/lavis/processors/randaugment.py +393 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/mm_utils.py +129 -0
- evalscope/metrics/t2v_metrics/models/vqascore_models/vqa_model.py +18 -0
- evalscope/metrics/t2v_metrics/score.py +78 -0
- evalscope/metrics/t2v_metrics/vqascore.py +14 -0
- evalscope/models/__init__.py +23 -13
- evalscope/models/image_edit_model.py +125 -0
- evalscope/models/mockllm.py +65 -0
- evalscope/models/model_apis.py +69 -0
- evalscope/models/modelscope.py +455 -0
- evalscope/models/openai_compatible.py +144 -0
- evalscope/models/text2image_model.py +124 -0
- evalscope/models/utils/openai.py +708 -0
- evalscope/perf/__init__.py +0 -1
- evalscope/perf/arguments.py +103 -69
- evalscope/perf/benchmark.py +114 -163
- evalscope/perf/http_client.py +59 -89
- evalscope/perf/main.py +91 -18
- evalscope/perf/plugin/__init__.py +3 -2
- evalscope/perf/plugin/api/__init__.py +4 -3
- evalscope/perf/plugin/api/base.py +27 -7
- evalscope/perf/plugin/api/custom_api.py +170 -57
- evalscope/perf/plugin/api/dashscope_api.py +4 -10
- evalscope/perf/plugin/api/default_api.py +214 -0
- evalscope/perf/plugin/api/openai_api.py +120 -41
- evalscope/perf/plugin/datasets/__init__.py +10 -6
- evalscope/perf/plugin/datasets/base.py +43 -1
- evalscope/perf/plugin/datasets/custom.py +22 -3
- evalscope/perf/plugin/datasets/flickr8k.py +5 -27
- evalscope/perf/plugin/datasets/kontext_bench.py +28 -0
- evalscope/perf/plugin/datasets/line_by_line.py +7 -3
- evalscope/perf/plugin/datasets/longalpaca.py +7 -3
- evalscope/perf/plugin/datasets/openqa.py +13 -14
- evalscope/perf/plugin/datasets/random_dataset.py +67 -0
- evalscope/perf/plugin/datasets/random_vl_dataset.py +80 -0
- evalscope/perf/plugin/datasets/speed_benchmark.py +11 -0
- evalscope/perf/plugin/registry.py +36 -16
- evalscope/perf/utils/analysis_result.py +24 -23
- evalscope/perf/utils/benchmark_util.py +95 -55
- evalscope/perf/utils/db_util.py +115 -78
- evalscope/perf/utils/local_server.py +12 -47
- evalscope/perf/utils/log_utils.py +63 -0
- evalscope/perf/utils/rich_display.py +192 -0
- evalscope/report/__init__.py +46 -3
- evalscope/report/combinator.py +143 -32
- evalscope/report/generator.py +74 -34
- evalscope/report/report.py +238 -0
- evalscope/run.py +71 -46
- evalscope/summarizer.py +5 -5
- evalscope/third_party/longbench_write/infer.py +1 -1
- evalscope/third_party/thinkbench/__init__.py +3 -0
- evalscope/third_party/thinkbench/eval.py +441 -0
- evalscope/third_party/thinkbench/infer.py +130 -0
- evalscope/third_party/thinkbench/resources/critique_template.txt +17 -0
- evalscope/third_party/thinkbench/resources/reformat_template.txt +31 -0
- evalscope/third_party/thinkbench/tools/__init__.py +0 -0
- evalscope/third_party/thinkbench/tools/llm.py +48 -0
- evalscope/third_party/thinkbench/tools/utils.py +13 -0
- evalscope/third_party/toolbench_static/llm/swift_infer.py +46 -20
- evalscope/third_party/toolbench_static/toolbench_static.py +2 -1
- evalscope/utils/__init__.py +82 -2
- evalscope/utils/argument_utils.py +64 -0
- evalscope/utils/chat_service.py +8 -6
- evalscope/utils/deprecation_utils.py +53 -0
- evalscope/utils/function_utils.py +266 -0
- evalscope/utils/import_utils.py +154 -0
- evalscope/utils/io_utils.py +336 -8
- evalscope/utils/json_schema.py +231 -0
- evalscope/utils/logger.py +121 -31
- evalscope/utils/model_utils.py +57 -1
- evalscope/utils/multi_choices.py +303 -0
- evalscope/utils/ner.py +377 -0
- evalscope/utils/url_utils.py +65 -0
- evalscope/version.py +2 -2
- evalscope-1.2.0.dist-info/METADATA +553 -0
- evalscope-1.2.0.dist-info/RECORD +628 -0
- {evalscope-0.10.0.dist-info → evalscope-1.2.0.dist-info}/WHEEL +1 -1
- {evalscope-0.10.0.dist-info → evalscope-1.2.0.dist-info}/top_level.txt +0 -1
- evalscope/backend/vlm_eval_kit/custom_dataset.py +0 -46
- evalscope/benchmarks/arc/ai2_arc.py +0 -151
- evalscope/benchmarks/benchmark.py +0 -76
- evalscope/benchmarks/ceval/ceval_exam.py +0 -146
- evalscope/benchmarks/ceval/samples.jsonl +0 -1
- evalscope/benchmarks/cmmlu/cmmlu.py +0 -161
- evalscope/benchmarks/cmmlu/samples.jsonl +0 -5
- evalscope/benchmarks/competition_math/competition_math.py +0 -79
- evalscope/benchmarks/data_adapter.py +0 -291
- evalscope/benchmarks/gsm8k/gsm8k.py +0 -121
- evalscope/benchmarks/hellaswag/hellaswag.py +0 -112
- evalscope/benchmarks/humaneval/humaneval.py +0 -79
- evalscope/benchmarks/mmlu/mmlu.py +0 -160
- evalscope/benchmarks/mmlu/samples.jsonl +0 -5
- evalscope/benchmarks/race/race.py +0 -104
- evalscope/benchmarks/race/samples.jsonl +0 -5
- evalscope/benchmarks/trivia_qa/trivia_qa.py +0 -89
- evalscope/benchmarks/truthful_qa/truthful_qa.py +0 -163
- evalscope/collections/evaluator.py +0 -198
- evalscope/evaluator/rating_eval.py +0 -157
- evalscope/evaluator/reviewer/__init__.py +0 -1
- evalscope/evaluator/reviewer/auto_reviewer.py +0 -391
- evalscope/metrics/code_metric.py +0 -98
- evalscope/metrics/named_metrics.py +0 -17
- evalscope/metrics/resources/gpt2-zhcn3-v4.bpe +0 -58485
- evalscope/metrics/resources/gpt2-zhcn3-v4.json +0 -1
- evalscope/models/base_adapter.py +0 -52
- evalscope/models/chat_adapter.py +0 -138
- evalscope/models/choice_adapter.py +0 -211
- evalscope/models/custom/__init__.py +0 -3
- evalscope/models/custom/custom_model.py +0 -53
- evalscope/models/custom/dummy_model.py +0 -63
- evalscope/models/custom_adapter.py +0 -67
- evalscope/models/local_model.py +0 -74
- evalscope/models/model.py +0 -229
- evalscope/models/server_adapter.py +0 -111
- evalscope/registry/__init__.py +0 -1
- evalscope/registry/config/cfg_arena.yaml +0 -77
- evalscope/registry/config/cfg_arena_zhihu.yaml +0 -63
- evalscope/registry/config/cfg_pairwise_baseline.yaml +0 -83
- evalscope/registry/config/cfg_single.yaml +0 -78
- evalscope/registry/data/prompt_template/lmsys_v2.jsonl +0 -8
- evalscope/registry/data/prompt_template/prompt_templates.jsonl +0 -8
- evalscope/registry/data/qa_browser/battle.jsonl +0 -634
- evalscope/registry/data/qa_browser/category_mapping.yaml +0 -10
- evalscope/registry/data/question.jsonl +0 -80
- evalscope/registry/tasks/arc.yaml +0 -28
- evalscope/registry/tasks/bbh.yaml +0 -26
- evalscope/registry/tasks/bbh_mini.yaml +0 -26
- evalscope/registry/tasks/ceval.yaml +0 -27
- evalscope/registry/tasks/ceval_mini.yaml +0 -26
- evalscope/registry/tasks/cmmlu.yaml +0 -27
- evalscope/registry/tasks/eval_qwen-7b-chat_v100.yaml +0 -28
- evalscope/registry/tasks/general_qa.yaml +0 -27
- evalscope/registry/tasks/gsm8k.yaml +0 -29
- evalscope/registry/tasks/mmlu.yaml +0 -29
- evalscope/registry/tasks/mmlu_mini.yaml +0 -27
- evalscope/report/app.py +0 -506
- evalscope/report/utils.py +0 -133
- evalscope/run_arena.py +0 -202
- evalscope/utils/arena_utils.py +0 -217
- evalscope/utils/completion_parsers.py +0 -82
- evalscope/utils/utils.py +0 -301
- evalscope-0.10.0.dist-info/METADATA +0 -565
- evalscope-0.10.0.dist-info/RECORD +0 -286
- tests/__init__.py +0 -1
- tests/cli/__init__.py +0 -1
- tests/cli/test_collection.py +0 -57
- tests/cli/test_run.py +0 -165
- tests/perf/__init__.py +0 -1
- tests/perf/test_perf.py +0 -101
- tests/rag/test_clip_benchmark.py +0 -85
- tests/rag/test_mteb.py +0 -138
- tests/rag/test_ragas.py +0 -120
- tests/swift/__init__.py +0 -1
- tests/swift/test_run_swift_eval.py +0 -145
- tests/swift/test_run_swift_vlm_eval.py +0 -127
- tests/swift/test_run_swift_vlm_jugde_eval.py +0 -156
- tests/test_run_all.py +0 -12
- tests/vlm/__init__.py +0 -1
- tests/vlm/test_vlmeval.py +0 -60
- {tests/rag → evalscope/api}/__init__.py +0 -0
- {evalscope-0.10.0.dist-info → evalscope-1.2.0.dist-info}/entry_points.txt +0 -0
- {evalscope-0.10.0.dist-info → evalscope-1.2.0.dist-info/licenses}/LICENSE +0 -0
evalscope/models/model.py
DELETED
|
@@ -1,229 +0,0 @@
|
|
|
1
|
-
# Copyright (c) Alibaba, Inc. and its affiliates.
|
|
2
|
-
import os
|
|
3
|
-
import random
|
|
4
|
-
import time
|
|
5
|
-
from abc import ABC, abstractmethod
|
|
6
|
-
from typing import Any
|
|
7
|
-
|
|
8
|
-
from evalscope.utils.logger import get_logger
|
|
9
|
-
|
|
10
|
-
logger = get_logger()
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
class BaseModel(ABC):
|
|
14
|
-
|
|
15
|
-
def __init__(self, model_cfg: dict, **kwargs):
|
|
16
|
-
"""
|
|
17
|
-
Base model class.
|
|
18
|
-
|
|
19
|
-
Args:
|
|
20
|
-
model_cfg (dict): The model configuration. Depending on the specific model. Example:
|
|
21
|
-
{'model_id': 'modelscope/Llama-2-7b-chat-ms', 'revision': 'v1.0.0'}
|
|
22
|
-
|
|
23
|
-
**kwargs: kwargs
|
|
24
|
-
"""
|
|
25
|
-
self.model_cfg: dict = model_cfg
|
|
26
|
-
self.kwargs = kwargs
|
|
27
|
-
|
|
28
|
-
@abstractmethod
|
|
29
|
-
def predict(self, *args, **kwargs) -> Any:
|
|
30
|
-
"""
|
|
31
|
-
Model prediction func.
|
|
32
|
-
"""
|
|
33
|
-
raise NotImplementedError
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
class ChatBaseModel(BaseModel):
|
|
37
|
-
|
|
38
|
-
def __init__(self, model_cfg: dict, **kwargs):
|
|
39
|
-
"""
|
|
40
|
-
Chat base model class. Depending on the specific model.
|
|
41
|
-
|
|
42
|
-
Args:
|
|
43
|
-
model_cfg (dict):
|
|
44
|
-
{'model_id': 'modelscope/Llama-2-7b-chat-ms', 'revision': 'v1.0.0', 'device_map': 'auto'}
|
|
45
|
-
|
|
46
|
-
**kwargs: kwargs
|
|
47
|
-
"""
|
|
48
|
-
super(ChatBaseModel, self).__init__(model_cfg=model_cfg, **kwargs)
|
|
49
|
-
|
|
50
|
-
@abstractmethod
|
|
51
|
-
def predict(self, inputs: dict, **kwargs) -> dict:
|
|
52
|
-
"""
|
|
53
|
-
Model prediction func. The inputs and outputs are compatible with OpenAI Chat Completions APIs.
|
|
54
|
-
Refer to: https://platform.openai.com/docs/guides/gpt/chat-completions-api
|
|
55
|
-
|
|
56
|
-
# TODO: follow latest OpenAI API
|
|
57
|
-
|
|
58
|
-
Args:
|
|
59
|
-
inputs (dict): The input prompts and history. Input format:
|
|
60
|
-
{'messages': [
|
|
61
|
-
{'role': 'system', 'content': 'You are a helpful assistant.'},
|
|
62
|
-
{'role': 'user', 'content': 'Who won the world series in 2020?'},
|
|
63
|
-
{'role': 'assistant', 'content': 'The Los Angeles Dodgers won the World Series in 2020.'},
|
|
64
|
-
]
|
|
65
|
-
'history': [
|
|
66
|
-
{'role': 'system', 'content': 'Hello'},
|
|
67
|
-
{'role': 'user', 'content': 'Hi'}]
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
kwargs (dict): Could be inference configuration. Default: None.
|
|
71
|
-
cfg format: {'max_length': 1024}
|
|
72
|
-
|
|
73
|
-
Returns: The result format:
|
|
74
|
-
{
|
|
75
|
-
'choices': [
|
|
76
|
-
{
|
|
77
|
-
'index': 0,
|
|
78
|
-
'message': {
|
|
79
|
-
'content': 'The 2020 World Series was played in Texas at Globe Life Field in Arlington.',
|
|
80
|
-
'role': 'assistant'
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
],
|
|
84
|
-
'created': 1677664795,
|
|
85
|
-
# For models on the ModelScope or HuggingFace, concat model_id and revision with "-".
|
|
86
|
-
'model': 'gpt-3.5-turbo-0613',
|
|
87
|
-
'object': 'chat.completion',
|
|
88
|
-
'usage': {
|
|
89
|
-
'completion_tokens': 17,
|
|
90
|
-
'prompt_tokens': 57,
|
|
91
|
-
'total_tokens': 74
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
"""
|
|
95
|
-
raise NotImplementedError
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
class OpenAIModel(ChatBaseModel):
|
|
99
|
-
"""
|
|
100
|
-
APIs of OpenAI models.
|
|
101
|
-
Available models: gpt-3.5-turbo, gpt-4
|
|
102
|
-
"""
|
|
103
|
-
|
|
104
|
-
MAX_RETRIES = 3
|
|
105
|
-
|
|
106
|
-
def __init__(self, model_cfg: dict, **kwargs):
|
|
107
|
-
super(OpenAIModel, self).__init__(model_cfg=model_cfg, **kwargs)
|
|
108
|
-
|
|
109
|
-
openai_api_key = os.environ.get('OPENAI_API_KEY', None)
|
|
110
|
-
self.api_key = self.model_cfg.get('api_key', openai_api_key)
|
|
111
|
-
|
|
112
|
-
if not self.api_key:
|
|
113
|
-
logger.error('OpenAI API key is not provided, please set it in environment variable OPENAI_API_KEY')
|
|
114
|
-
# raise ValueError(
|
|
115
|
-
# 'OpenAI API key is not provided, '
|
|
116
|
-
# 'please set it in environment variable OPENAI_API_KEY')
|
|
117
|
-
|
|
118
|
-
def predict(self, model_id: str, inputs: dict, **kwargs) -> dict:
|
|
119
|
-
|
|
120
|
-
sys_prompt: str = inputs.get('sys_prompt', '')
|
|
121
|
-
user_prompt: str = inputs.get('user_prompt', '')
|
|
122
|
-
|
|
123
|
-
# model_id: str = kwargs.get('model_id', '')
|
|
124
|
-
temperature: float = kwargs.pop('temperature', 0.2)
|
|
125
|
-
max_tokens: int = kwargs.pop('max_tokens', 1024)
|
|
126
|
-
mode: str = kwargs.pop('mode', 'chat.completion')
|
|
127
|
-
|
|
128
|
-
logger.info(f'Using OpenAI model_id: {model_id}')
|
|
129
|
-
|
|
130
|
-
res = self._predict(
|
|
131
|
-
model_id=model_id,
|
|
132
|
-
sys_prompt=sys_prompt,
|
|
133
|
-
user_prompt=user_prompt,
|
|
134
|
-
temperature=temperature,
|
|
135
|
-
max_tokens=max_tokens,
|
|
136
|
-
mode=mode)
|
|
137
|
-
|
|
138
|
-
return res
|
|
139
|
-
|
|
140
|
-
def _predict(
|
|
141
|
-
self,
|
|
142
|
-
model_id,
|
|
143
|
-
sys_prompt,
|
|
144
|
-
user_prompt,
|
|
145
|
-
temperature,
|
|
146
|
-
max_tokens,
|
|
147
|
-
mode: str = 'chat.completion',
|
|
148
|
-
) -> dict:
|
|
149
|
-
import openai
|
|
150
|
-
|
|
151
|
-
res = {}
|
|
152
|
-
openai.api_key = self.api_key
|
|
153
|
-
|
|
154
|
-
for i in range(self.MAX_RETRIES):
|
|
155
|
-
try:
|
|
156
|
-
if mode == 'chat.completion':
|
|
157
|
-
resp = openai.ChatCompletion.create(
|
|
158
|
-
model=model_id,
|
|
159
|
-
messages=[{
|
|
160
|
-
'role': 'system',
|
|
161
|
-
'content': sys_prompt
|
|
162
|
-
}, {
|
|
163
|
-
'role': 'user',
|
|
164
|
-
'content': user_prompt
|
|
165
|
-
}],
|
|
166
|
-
temperature=temperature,
|
|
167
|
-
max_tokens=max_tokens)
|
|
168
|
-
|
|
169
|
-
if resp:
|
|
170
|
-
ans_text = resp['choices'][0]['message']['content']
|
|
171
|
-
model_id = resp['model']
|
|
172
|
-
else:
|
|
173
|
-
logger.warning(f'OpenAI GPT API call failed: got empty response '
|
|
174
|
-
f'for input {sys_prompt} {user_prompt}')
|
|
175
|
-
ans_text = ''
|
|
176
|
-
model_id = ''
|
|
177
|
-
|
|
178
|
-
res['ans_text'] = ans_text
|
|
179
|
-
res['model_id'] = model_id
|
|
180
|
-
else:
|
|
181
|
-
raise ValueError(f'Invalid mode: {mode}')
|
|
182
|
-
|
|
183
|
-
return res
|
|
184
|
-
|
|
185
|
-
except Exception as e:
|
|
186
|
-
logger.warning(f'OpenAI API call failed: {e}')
|
|
187
|
-
time.sleep(3)
|
|
188
|
-
logger.error(f'OpenAI API call failed after {self.MAX_RETRIES} retries')
|
|
189
|
-
return res
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
class DummyChatModel(ChatBaseModel):
|
|
193
|
-
|
|
194
|
-
MODEL_ID = 'dummy_chat_model_0801'
|
|
195
|
-
REVISION = 'v1.0.0'
|
|
196
|
-
|
|
197
|
-
def __init__(self, model_cfg: dict, **kwargs):
|
|
198
|
-
model_cfg['model_id'] = self.MODEL_ID
|
|
199
|
-
model_cfg['revision'] = self.REVISION
|
|
200
|
-
super(DummyChatModel, self).__init__(model_cfg=model_cfg)
|
|
201
|
-
|
|
202
|
-
def predict(self, inputs: dict, **kwargs) -> dict:
|
|
203
|
-
|
|
204
|
-
debug: bool = False
|
|
205
|
-
if debug:
|
|
206
|
-
messages = inputs['messages']
|
|
207
|
-
history = inputs['history']
|
|
208
|
-
|
|
209
|
-
logger.info(f'** messages: {messages}')
|
|
210
|
-
logger.info(f'** history: {history}')
|
|
211
|
-
|
|
212
|
-
choice = random.choice(['A', 'B', 'C', 'D'])
|
|
213
|
-
|
|
214
|
-
# Build response
|
|
215
|
-
res = {
|
|
216
|
-
'choices': [{
|
|
217
|
-
'index': 0,
|
|
218
|
-
'message': {
|
|
219
|
-
'content': choice,
|
|
220
|
-
'role': 'assistant'
|
|
221
|
-
}
|
|
222
|
-
}],
|
|
223
|
-
'created': time.time(),
|
|
224
|
-
'model': self.MODEL_ID + '-' + self.REVISION,
|
|
225
|
-
'object': 'chat.completion',
|
|
226
|
-
'usage': {}
|
|
227
|
-
}
|
|
228
|
-
|
|
229
|
-
return res
|
|
@@ -1,111 +0,0 @@
|
|
|
1
|
-
import requests
|
|
2
|
-
import time
|
|
3
|
-
from typing import Optional, Union
|
|
4
|
-
|
|
5
|
-
from evalscope.models.base_adapter import BaseModelAdapter
|
|
6
|
-
from evalscope.utils.chat_service import ChatMessage
|
|
7
|
-
from evalscope.utils.logger import get_logger
|
|
8
|
-
|
|
9
|
-
logger = get_logger()
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
class ServerModelAdapter(BaseModelAdapter):
|
|
13
|
-
"""
|
|
14
|
-
Server model adapter to request remote API model and generate results.
|
|
15
|
-
"""
|
|
16
|
-
|
|
17
|
-
def __init__(self, api_url: str, model_id: str, api_key: str = 'EMPTY', **kwargs):
|
|
18
|
-
"""
|
|
19
|
-
Args:
|
|
20
|
-
api_url: The URL of the remote API model.
|
|
21
|
-
model_id: The ID of the remote API model.
|
|
22
|
-
api_key: The API key of the remote API model.
|
|
23
|
-
"""
|
|
24
|
-
self.api_url = api_url
|
|
25
|
-
self.model_id = model_id
|
|
26
|
-
self.api_key = api_key
|
|
27
|
-
self.seed = kwargs.get('seed', None)
|
|
28
|
-
self.model_cfg = {'api_url': api_url, 'model_id': model_id, 'api_key': api_key}
|
|
29
|
-
super().__init__(model=None, model_cfg=self.model_cfg, **kwargs)
|
|
30
|
-
|
|
31
|
-
def predict(self, inputs: Union[str, dict, list], infer_cfg: dict = None) -> dict:
|
|
32
|
-
"""
|
|
33
|
-
Model prediction func.
|
|
34
|
-
|
|
35
|
-
Args:
|
|
36
|
-
inputs (Union[str, dict, list]): The input data.
|
|
37
|
-
infer_cfg (dict): Inference configuration.
|
|
38
|
-
|
|
39
|
-
Returns:
|
|
40
|
-
res (dict): The model prediction results.
|
|
41
|
-
"""
|
|
42
|
-
infer_cfg = infer_cfg or {}
|
|
43
|
-
|
|
44
|
-
# Process inputs
|
|
45
|
-
if isinstance(inputs, str):
|
|
46
|
-
query = inputs
|
|
47
|
-
system_prompt = None
|
|
48
|
-
elif isinstance(inputs, dict):
|
|
49
|
-
data: list = inputs['data']
|
|
50
|
-
if isinstance(data[0], tuple): # for truthful_qa and hellaswag
|
|
51
|
-
query = '\n'.join(''.join(item) for item in data)
|
|
52
|
-
system_prompt = inputs.get('system_prompt', None)
|
|
53
|
-
else:
|
|
54
|
-
query = data[0]
|
|
55
|
-
system_prompt = inputs.get('system_prompt', None)
|
|
56
|
-
elif isinstance(inputs, list):
|
|
57
|
-
query = '\n'.join(inputs)
|
|
58
|
-
system_prompt = None
|
|
59
|
-
else:
|
|
60
|
-
raise TypeError(f'Unsupported inputs type: {type(inputs)}')
|
|
61
|
-
|
|
62
|
-
content = self.make_request_content(query, system_prompt)
|
|
63
|
-
request_json = self.make_request(content, infer_cfg)
|
|
64
|
-
response = self.send_request(request_json)
|
|
65
|
-
return response
|
|
66
|
-
|
|
67
|
-
def make_request_content(self, query: str, system_prompt: Optional[str] = None) -> dict:
|
|
68
|
-
"""
|
|
69
|
-
Make request content for API.
|
|
70
|
-
"""
|
|
71
|
-
if system_prompt is not None:
|
|
72
|
-
messages = [
|
|
73
|
-
ChatMessage(role='system', content=system_prompt).model_dump(exclude_unset=True),
|
|
74
|
-
ChatMessage(role='user', content=query).model_dump(exclude_unset=True)
|
|
75
|
-
]
|
|
76
|
-
else:
|
|
77
|
-
messages = [ChatMessage(role='user', content=query).model_dump(exclude_unset=True)]
|
|
78
|
-
return {'messages': messages}
|
|
79
|
-
|
|
80
|
-
def make_request(self, content: dict, infer_cfg: dict = {}) -> dict:
|
|
81
|
-
"""Make request to remote API."""
|
|
82
|
-
# Format request JSON according to OpenAI API format
|
|
83
|
-
do_sample = infer_cfg.get('do_sample', False)
|
|
84
|
-
temperature = infer_cfg.get('temperature', 0.0) if do_sample else 0.0
|
|
85
|
-
|
|
86
|
-
request_json = {
|
|
87
|
-
**content, 'model': self.model_id,
|
|
88
|
-
'max_tokens': infer_cfg.get('max_tokens', 2048),
|
|
89
|
-
'temperature': temperature,
|
|
90
|
-
'top_p': infer_cfg.get('top_p', 1.0),
|
|
91
|
-
'n': infer_cfg.get('num_return_sequences', 1),
|
|
92
|
-
'stop': infer_cfg.get('stop', None)
|
|
93
|
-
}
|
|
94
|
-
if self.seed is not None:
|
|
95
|
-
request_json['seed'] = self.seed
|
|
96
|
-
logger.debug(f'Request to remote API: {request_json}')
|
|
97
|
-
return request_json
|
|
98
|
-
|
|
99
|
-
def send_request(self, request_json: dict, max_retries: int = 3) -> dict:
|
|
100
|
-
for attempt in range(max_retries):
|
|
101
|
-
response = requests.post(
|
|
102
|
-
self.api_url, json=request_json, headers={'Authorization': f'Bearer {self.api_key}'})
|
|
103
|
-
if response.status_code == 200:
|
|
104
|
-
response_data = response.json()
|
|
105
|
-
return response_data
|
|
106
|
-
logger.warning(f'Failed to request to remote API: {response.status_code} {response.text}')
|
|
107
|
-
if attempt < max_retries - 1:
|
|
108
|
-
time.sleep(5) # Sleep for 5 seconds before retrying
|
|
109
|
-
else:
|
|
110
|
-
raise RuntimeError(f'Failed to request to remote API after {max_retries} attempts: '
|
|
111
|
-
f'{response.status_code} {response.text}')
|
evalscope/registry/__init__.py
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
# Copyright (c) Alibaba, Inc. and its affiliates.
|
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
# input raw data
|
|
2
|
-
question_file: registry/data/question.jsonl
|
|
3
|
-
|
|
4
|
-
# candidate models to be battled
|
|
5
|
-
answers_gen:
|
|
6
|
-
chatglm3-6b:
|
|
7
|
-
# model_id_or_path could be local absolute path, e.g. /to/path/.cache/modelscope/ZhipuAI/chatglm3-6b
|
|
8
|
-
model_id_or_path: ZhipuAI/chatglm3-6b # model_id on modelscope
|
|
9
|
-
revision: v1.0.2 # revision of model, default is NULL
|
|
10
|
-
precision: torch.float16
|
|
11
|
-
enable: true # enable or disable this model
|
|
12
|
-
template_type: chatglm3 # see: https://github.com/modelscope/swift/blob/main/docs/source/LLM/%E6%94%AF%E6%8C%81%E7%9A%84%E6%A8%A1%E5%9E%8B%E5%92%8C%E6%95%B0%E6%8D%AE%E9%9B%86.md
|
|
13
|
-
generation_config:
|
|
14
|
-
do_sample: true
|
|
15
|
-
max_new_tokens: 256
|
|
16
|
-
top_k: 20
|
|
17
|
-
top_p: 0.75
|
|
18
|
-
temperature: 0.333
|
|
19
|
-
# output predicted answer file name
|
|
20
|
-
output_file: registry/data/arena/answers/answer_chatglm3-6b.jsonl
|
|
21
|
-
Baichuan2-7B-Base:
|
|
22
|
-
model_id_or_path: baichuan-inc/Baichuan2-7B-Base
|
|
23
|
-
revision: v1.0.2 # revision of model, default is NULL
|
|
24
|
-
precision: torch.float16
|
|
25
|
-
enable: false # enable or disable this model
|
|
26
|
-
template_type: default-generation
|
|
27
|
-
generation_config:
|
|
28
|
-
do_sample: true
|
|
29
|
-
max_new_tokens: 256
|
|
30
|
-
top_k: 20
|
|
31
|
-
top_p: 0.75
|
|
32
|
-
temperature: 0.3
|
|
33
|
-
output_file: registry/data/arena/answers/answer_Baichuan2-7B-Base.jsonl
|
|
34
|
-
Qwen-7B:
|
|
35
|
-
model_id_or_path: qwen/Qwen-7B
|
|
36
|
-
revision: v1.1.8 # revision of model, default is NULL
|
|
37
|
-
precision: torch.float16
|
|
38
|
-
enable: true # enable or disable this model # TODO: tokenizer issue
|
|
39
|
-
template_type: default-generation
|
|
40
|
-
generation_config:
|
|
41
|
-
do_sample: true
|
|
42
|
-
max_new_tokens: 256
|
|
43
|
-
top_k: 20
|
|
44
|
-
top_p: 0.75
|
|
45
|
-
temperature: 0.3
|
|
46
|
-
output_file: registry/data/arena/answers/answer_Qwen-7B.jsonl
|
|
47
|
-
|
|
48
|
-
# Auto-reviewer(GPT-4) config
|
|
49
|
-
reviews_gen:
|
|
50
|
-
enable: true
|
|
51
|
-
reviewer:
|
|
52
|
-
# class reference of auto reviewer(GPT-4)
|
|
53
|
-
ref: evalscope.evaluator.reviewer.auto_reviewer:AutoReviewerGpt4
|
|
54
|
-
args:
|
|
55
|
-
max_tokens: 1024
|
|
56
|
-
temperature: 0.2
|
|
57
|
-
# options: pairwise, pairwise_baseline, single (default is pairwise)
|
|
58
|
-
mode: pairwise
|
|
59
|
-
# position bias mitigation strategy, options: swap_position, randomize_order, NULL. default is NULL
|
|
60
|
-
position_bias_mitigation: NULL
|
|
61
|
-
# completion parser config, default is lmsys_parser
|
|
62
|
-
fn_completion_parser: lmsys_parser
|
|
63
|
-
# prompt templates for auto reviewer(GPT-4)
|
|
64
|
-
prompt_file: registry/data/prompt_template/prompt_templates.jsonl
|
|
65
|
-
# target answer files list to be reviewed,
|
|
66
|
-
# could be replaced by your own path: ['/path/to/answers_model_1.jsonl', '/path/to/answers_model_2.jsonl', ...]
|
|
67
|
-
# Default is NULL, which means all answers in answers_gen will be reviewed
|
|
68
|
-
target_answers: NULL
|
|
69
|
-
# output file name of auto reviewer
|
|
70
|
-
review_file: registry/data/arena/reviews/review_gpt4.jsonl
|
|
71
|
-
|
|
72
|
-
# rating results
|
|
73
|
-
rating_gen:
|
|
74
|
-
enable: true
|
|
75
|
-
metrics: ['elo']
|
|
76
|
-
# elo rating report file name
|
|
77
|
-
report_file: registry/data/arena/reports/elo_rating_origin.csv
|
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
# input raw data
|
|
2
|
-
question_file: registry/data/question.jsonl
|
|
3
|
-
|
|
4
|
-
# candidate models to be battled
|
|
5
|
-
answers_gen:
|
|
6
|
-
Qwen2-7B-Instruct:
|
|
7
|
-
model_id_or_path: /mnt/data/data/user/maoyunlin.myl/models/Qwen2-7B-Instruct # model_id on modelscope
|
|
8
|
-
revision: NULL # revision of model, default is NULL
|
|
9
|
-
precision: torch.float16
|
|
10
|
-
enable: true # enable or disable this model
|
|
11
|
-
template_type: default-generation # see: https://github.com/modelscope/swift/blob/main/docs/source/LLM/%E6%94%AF%E6%8C%81%E7%9A%84%E6%A8%A1%E5%9E%8B%E5%92%8C%E6%95%B0%E6%8D%AE%E9%9B%86.md
|
|
12
|
-
generation_config:
|
|
13
|
-
do_sample: true
|
|
14
|
-
max_new_tokens: 512
|
|
15
|
-
top_k: 20
|
|
16
|
-
top_p: 0.9
|
|
17
|
-
temperature: 0.7
|
|
18
|
-
# output predicted answer file name
|
|
19
|
-
output_file: registry/data/arena/answers/answer_qwen2.jsonl
|
|
20
|
-
Qwen-7B:
|
|
21
|
-
model_id_or_path: /mnt/data/data/user/maoyunlin.myl/output/qwen2-7b-instruct/v25-20240809-113533/checkpoint-309-merged
|
|
22
|
-
revision: NULL # revision of model, default is NULL
|
|
23
|
-
precision: torch.float16
|
|
24
|
-
enable: true # enable or disable this model
|
|
25
|
-
template_type: default-generation
|
|
26
|
-
generation_config:
|
|
27
|
-
do_sample: true
|
|
28
|
-
max_new_tokens: 512
|
|
29
|
-
top_k: 20
|
|
30
|
-
top_p: 0.9
|
|
31
|
-
temperature: 0.7
|
|
32
|
-
output_file: registry/data/arena/answers/answer_Qwen-7B.jsonl
|
|
33
|
-
|
|
34
|
-
# Auto-reviewer(GPT-4) config
|
|
35
|
-
reviews_gen:
|
|
36
|
-
enable: true
|
|
37
|
-
reviewer:
|
|
38
|
-
# class reference of auto reviewer(GPT-4)
|
|
39
|
-
ref: evalscope.evaluator.reviewer.auto_reviewer:AutoReviewerGpt4
|
|
40
|
-
args:
|
|
41
|
-
max_tokens: 1024
|
|
42
|
-
temperature: 0.2
|
|
43
|
-
# options: pairwise, pairwise_baseline, single (default is pairwise)
|
|
44
|
-
mode: pairwise
|
|
45
|
-
# position bias mitigation strategy, options: swap_position, randomize_order, NULL. default is NULL
|
|
46
|
-
position_bias_mitigation: NULL
|
|
47
|
-
# completion parser config, default is lmsys_parser
|
|
48
|
-
fn_completion_parser: lmsys_parser
|
|
49
|
-
# prompt templates for auto reviewer(GPT-4)
|
|
50
|
-
prompt_file: registry/data/prompt_template/prompt_templates.jsonl
|
|
51
|
-
# target answer files list to be reviewed,
|
|
52
|
-
# could be replaced by your own path: ['/path/to/answers_model_1.jsonl', '/path/to/answers_model_2.jsonl', ...]
|
|
53
|
-
# Default is NULL, which means all answers in answers_gen will be reviewed
|
|
54
|
-
target_answers: NULL
|
|
55
|
-
# output file name of auto reviewer
|
|
56
|
-
review_file: registry/data/arena/reviews/review_gpt4.jsonl
|
|
57
|
-
|
|
58
|
-
# rating results
|
|
59
|
-
rating_gen:
|
|
60
|
-
enable: true
|
|
61
|
-
metrics: ['elo']
|
|
62
|
-
# elo rating report file name
|
|
63
|
-
report_file: registry/data/arena/reports/elo_rating_origin.csv
|
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
# input raw data
|
|
2
|
-
question_file: registry/data/question.jsonl
|
|
3
|
-
|
|
4
|
-
# candidate models to be battled
|
|
5
|
-
answers_gen:
|
|
6
|
-
chatglm3-6b:
|
|
7
|
-
# model_id_or_path could be local absolute path, e.g. /to/path/.cache/modelscope/ZhipuAI/chatglm3-6b
|
|
8
|
-
model_id_or_path: ZhipuAI/chatglm3-6b # model_id on modelscope
|
|
9
|
-
revision: v1.0.2 # revision of model, default is NULL
|
|
10
|
-
precision: torch.float16
|
|
11
|
-
enable: true # enable or disable this model
|
|
12
|
-
template_type: chatglm3 # see: https://github.com/modelscope/swift/blob/main/docs/source/LLM/%E6%94%AF%E6%8C%81%E7%9A%84%E6%A8%A1%E5%9E%8B%E5%92%8C%E6%95%B0%E6%8D%AE%E9%9B%86.md
|
|
13
|
-
generation_config:
|
|
14
|
-
do_sample: true
|
|
15
|
-
max_new_tokens: 256
|
|
16
|
-
top_k: 20
|
|
17
|
-
top_p: 0.75
|
|
18
|
-
temperature: 0.3
|
|
19
|
-
# output predicted answer file name
|
|
20
|
-
output_file: registry/data/arena/answers/answer_chatglm3-6b.jsonl
|
|
21
|
-
Baichuan2-7B-Base:
|
|
22
|
-
model_id_or_path: baichuan-inc/Baichuan2-7B-Base
|
|
23
|
-
revision: v1.0.2 # revision of model, default is NULL
|
|
24
|
-
precision: torch.float16
|
|
25
|
-
enable: false # enable or disable this model
|
|
26
|
-
template_type: default-generation
|
|
27
|
-
generation_config:
|
|
28
|
-
do_sample: true
|
|
29
|
-
max_new_tokens: 256
|
|
30
|
-
top_k: 20
|
|
31
|
-
top_p: 0.75
|
|
32
|
-
temperature: 0.3
|
|
33
|
-
output_file: registry/data/arena/answers/answer_Baichuan2-7B-Base.jsonl
|
|
34
|
-
Qwen-7B:
|
|
35
|
-
model_id_or_path: qwen/Qwen-7B
|
|
36
|
-
revision: v1.1.8 # revision of model, default is NULL
|
|
37
|
-
precision: torch.float16
|
|
38
|
-
enable: true # enable or disable this model # TODO: tokenizer issue
|
|
39
|
-
template_type: default-generation
|
|
40
|
-
generation_config:
|
|
41
|
-
do_sample: true
|
|
42
|
-
max_new_tokens: 256
|
|
43
|
-
top_k: 20
|
|
44
|
-
top_p: 0.75
|
|
45
|
-
temperature: 0.3
|
|
46
|
-
output_file: registry/data/arena/answers/answer_Qwen-7B.jsonl
|
|
47
|
-
|
|
48
|
-
# model of auto-reviewer
|
|
49
|
-
reviews_gen:
|
|
50
|
-
enable: true
|
|
51
|
-
reviewer:
|
|
52
|
-
ref: evalscope.evaluator.reviewer.auto_reviewer:AutoReviewerGpt4
|
|
53
|
-
args:
|
|
54
|
-
model: gpt-4
|
|
55
|
-
max_tokens: 1024
|
|
56
|
-
temperature: 0
|
|
57
|
-
# pairwise comparison against baseline
|
|
58
|
-
mode: pairwise_baseline
|
|
59
|
-
# position bias mitigation strategy, options: swap_position, randomize_order, None. default is None
|
|
60
|
-
position_bias_mitigation: swap_position
|
|
61
|
-
# completion parser config, default is lmsys_parser
|
|
62
|
-
fn_completion_parser: lmsys_parser
|
|
63
|
-
# target answers list to be reviewed, could be replaced by your own path: /path/to/answers.jsonl
|
|
64
|
-
target_answers: [registry/data/arena/answers/answer_chatglm3-6b.jsonl,
|
|
65
|
-
registry/data/arena/answers/answer_Baichuan2-7B-Base.jsonl]
|
|
66
|
-
# the path to the outputs of the baseline model
|
|
67
|
-
baseline_file: registry/data/arena/answers/answer_text_davinci_003.jsonl
|
|
68
|
-
# the path to the reference answers
|
|
69
|
-
reference_file:
|
|
70
|
-
# prompt templates for auto reviewer(GPT-4)
|
|
71
|
-
prompt_file: registry/data/prompt_template/lmsys_v2.jsonl
|
|
72
|
-
# output file of auto reviewer
|
|
73
|
-
review_file: registry/data/arena/reviews/review_gpt4_pair_baseline.jsonl
|
|
74
|
-
# cache file of auto reviewer
|
|
75
|
-
cache_file: registry/data/arena/reviews/review_gpt4_pair_baseline.jsonl
|
|
76
|
-
|
|
77
|
-
# rating results
|
|
78
|
-
rating_gen:
|
|
79
|
-
enable: true
|
|
80
|
-
metrics: ['pairwise']
|
|
81
|
-
baseline_model: text_davinci_003
|
|
82
|
-
# elo rating report file
|
|
83
|
-
report_file: registry/data/arena/reports/rating_pairwise_baseline.csv
|
|
@@ -1,78 +0,0 @@
|
|
|
1
|
-
# input raw data
|
|
2
|
-
question_file: registry/data/question.jsonl
|
|
3
|
-
|
|
4
|
-
# candidate models to be battled
|
|
5
|
-
answers_gen:
|
|
6
|
-
chatglm3-6b:
|
|
7
|
-
# model_id_or_path could be local absolute path, e.g. /to/path/.cache/modelscope/ZhipuAI/chatglm3-6b
|
|
8
|
-
model_id_or_path: ZhipuAI/chatglm3-6b # model_id on modelscope
|
|
9
|
-
revision: v1.0.2 # revision of model, default is NULL
|
|
10
|
-
precision: torch.float16
|
|
11
|
-
enable: true # enable or disable this model
|
|
12
|
-
template_type: chatglm3
|
|
13
|
-
generation_config:
|
|
14
|
-
do_sample: true
|
|
15
|
-
max_new_tokens: 256
|
|
16
|
-
top_k: 20
|
|
17
|
-
top_p: 0.75
|
|
18
|
-
temperature: 0.3
|
|
19
|
-
# output predicted answer file name
|
|
20
|
-
output_file: registry/data/arena/answers/answer_chatglm3-6b.jsonl
|
|
21
|
-
Baichuan2-7B-Base:
|
|
22
|
-
model_id_or_path: baichuan-inc/Baichuan2-7B-Base
|
|
23
|
-
revision: v1.0.2 # revision of model, default is NULL
|
|
24
|
-
precision: torch.float16
|
|
25
|
-
enable: false # enable or disable this model
|
|
26
|
-
template_type: default-generation
|
|
27
|
-
generation_config:
|
|
28
|
-
do_sample: true
|
|
29
|
-
max_new_tokens: 256
|
|
30
|
-
top_k: 20
|
|
31
|
-
top_p: 0.75
|
|
32
|
-
temperature: 0.3
|
|
33
|
-
output_file: registry/data/arena/answers/answer_Baichuan2-7B-Base.jsonl
|
|
34
|
-
Qwen-7B:
|
|
35
|
-
model_id_or_path: qwen/Qwen-7B
|
|
36
|
-
revision: v1.1.8 # revision of model, default is NULL
|
|
37
|
-
precision: torch.float16
|
|
38
|
-
enable: true # enable or disable this model # TODO: tokenizer issue
|
|
39
|
-
template_type: default-generation
|
|
40
|
-
generation_config:
|
|
41
|
-
do_sample: true
|
|
42
|
-
max_new_tokens: 256
|
|
43
|
-
top_k: 20
|
|
44
|
-
top_p: 0.75
|
|
45
|
-
temperature: 0.3
|
|
46
|
-
output_file: registry/data/arena/answers/answer_Qwen-7B.jsonl
|
|
47
|
-
|
|
48
|
-
# model of auto-reviewer
|
|
49
|
-
reviews_gen:
|
|
50
|
-
enable: true
|
|
51
|
-
reviewer:
|
|
52
|
-
ref: evalscope.evaluator.reviewer.auto_reviewer:AutoReviewerGpt4
|
|
53
|
-
args:
|
|
54
|
-
model: gpt-4
|
|
55
|
-
max_tokens: 1024
|
|
56
|
-
temperature: 0
|
|
57
|
-
# pairwise comparison against baseline
|
|
58
|
-
mode: single
|
|
59
|
-
# completion parser config, default is lmsys_parser
|
|
60
|
-
fn_completion_parser: lmsys_parser
|
|
61
|
-
# target answers list to be reviewed, could be replaced by your own path: /path/to/answers.jsonl
|
|
62
|
-
target_answers: [registry/data/arena/answers/answer_chatglm3-6b.jsonl,
|
|
63
|
-
registry/data/arena/answers/answer_Baichuan2-7B-Base.jsonl]
|
|
64
|
-
# the path to the reference answers
|
|
65
|
-
reference_file:
|
|
66
|
-
# prompt templates for auto reviewer(GPT-4)
|
|
67
|
-
prompt_file: registry/data/prompt_template/lmsys_v2.jsonl
|
|
68
|
-
# output file of auto reviewer
|
|
69
|
-
review_file: registry/data/arena/reviews/review_gpt4_single.jsonl
|
|
70
|
-
# cache file of auto reviewer
|
|
71
|
-
cache_file: registry/data/arena/reviews/review_gpt4_single.jsonl
|
|
72
|
-
|
|
73
|
-
# rating results
|
|
74
|
-
rating_gen:
|
|
75
|
-
enable: true
|
|
76
|
-
metrics: ['score']
|
|
77
|
-
# elo rating report file
|
|
78
|
-
report_file: registry/data/arena/reports/rating_single.csv
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
{"name": "pair-v2", "type": "pairwise", "system_prompt": "Please act as an impartial judge and evaluate the quality of the responses provided by two AI assistants to the user question displayed below. You should choose the assistant that follows the user's instructions and answers the user's question better. Your evaluation should consider factors such as the helpfulness, relevance, accuracy, depth, creativity, and level of detail of their responses. Begin your evaluation by comparing the two responses and provide a short explanation. Avoid any positional biases and ensure that the order in which the responses were presented does not influence your decision. Do not allow the length of the responses to influence your evaluation. Do not favor certain names of the assistants. Be as objective as possible. After providing your explanation, output your final verdict by strictly following this format: \"[[A]]\" if assistant A is better, \"[[B]]\" if assistant B is better, and \"[[C]]\" for a tie.", "prompt_template": "[User Question]\n{question}\n\n[The Start of Assistant A's Answer]\n{answer_a}\n[The End of Assistant A's Answer]\n\n[The Start of Assistant B's Answer]\n{answer_b}\n[The End of Assistant B's Answer]", "description": "Prompt for general questions", "category": "general", "output_format": "[[A]]"}
|
|
2
|
-
{"name": "pair-v2-multi-turn", "type": "pairwise", "system_prompt": "Please act as an impartial judge and evaluate the quality of the responses provided by two AI assistants to the user questions. You should choose the assistant that follows the user's instructions and answers the user's questions better. Your evaluation should consider factors such as the helpfulness, relevance, accuracy, depth, creativity, and level of detail of their responses. You should focus on who provides a better answer to the second user question. Begin your evaluation by comparing the responses of the two assistants and provide a short explanation. Avoid any positional biases and ensure that the order in which the responses were presented does not influence your decision. Do not allow the length of the responses to influence your evaluation. Do not favor certain names of the assistants. Be as objective as possible. After providing your explanation, output your final verdict by strictly following this format: \"[[A]]\" if assistant A is better, \"[[B]]\" if assistant B is better, and \"[[C]]\" for a tie.", "prompt_template": "<|The Start of Assistant A's Conversation with User|>\n\n### User:\n{question_1}\n\n### Assistant A:\n{answer_a_1}\n\n### User:\n{question_2}\n\n### Assistant A:\n{answer_a_2}\n\n<|The End of Assistant A's Conversation with User|>\n\n\n<|The Start of Assistant B's Conversation with User|>\n\n### User:\n{question_1}\n\n### Assistant B:\n{answer_b_1}\n\n### User:\n{question_2}\n\n### Assistant B:\n{answer_b_2}\n\n<|The End of Assistant B's Conversation with User|>", "description": "Prompt for multi-turn general questions", "category": "general", "output_format": "[[A]]"}
|
|
3
|
-
{"name": "pair-math-v1", "type": "pairwise", "system_prompt": "Please act as an impartial judge and evaluate the quality of the responses provided by two AI assistants to the user question displayed below. Your evaluation should consider correctness and helpfulness. You will be given a reference answer, assistant A's answer, and assistant B's answer. Your job is to evaluate which assistant's answer is better. Begin your evaluation by comparing both assistants' answers with the reference answer. Identify and correct any mistakes. Avoid any positional biases and ensure that the order in which the responses were presented does not influence your decision. Do not allow the length of the responses to influence your evaluation. Do not favor certain names of the assistants. Be as objective as possible. After providing your explanation, output your final verdict by strictly following this format: \"[[A]]\" if assistant A is better, \"[[B]]\" if assistant B is better, and \"[[C]]\" for a tie.", "prompt_template": "[User Question]\n{question}\n\n[The Start of Reference Answer]\n{ref_answer_1}\n[The End of Reference Answer]\n\n[The Start of Assistant A's Answer]\n{answer_a}\n[The End of Assistant A's Answer]\n\n[The Start of Assistant B's Answer]\n{answer_b}\n[The End of Assistant B's Answer]", "description": "Prompt for math questions", "category": ["math", "reasoning", "coding"], "output_format": "[[A]]"}
|
|
4
|
-
{"name": "pair-math-v1-multi-turn", "type": "pairwise", "system_prompt": "Please act as an impartial judge and evaluate the quality of the responses provided by two AI assistants to the user questions. Your evaluation should consider correctness and helpfulness. You will be given reference answers, the assistant A's answers, the assistant B's answers. Your job is to determine which assistant provides correct and helpful answers to the second user question. Begin your evaluation by comparing both assistants' answers with the reference answers. Identify and correct any mistakes. Avoid any positional biases and ensure that the order in which the responses were presented does not influence your decision. Do not allow the length of the responses to influence your evaluation. Do not favor certain names of the assistants. Be as objective as possible. After providing your explanation, output your final verdict by strictly following this format: \"[[A]]\" if assistant A is better, \"[[B]]\" if assistant B is better, and \"[[C]]\" for a tie.", "prompt_template": "<|The Start of Reference Answer|>\n\n### User:\n{question_1}\n\n### Reference answer:\n{ref_answer_1}\n\n### User:\n{question_2}\n\n### Reference answer:\n{ref_answer_2}\n\n<|The End of Reference Answer|>\n\n\n<|The Start of Assistant A's Conversation with User|>\n\n### User:\n{question_1}\n\n### Assistant A:\n{answer_a_1}\n\n### User:\n{question_2}\n\n### Assistant A:\n{answer_a_2}\n\n<|The End of Assistant A's Conversation with User|>\n\n\n<|The Start of Assistant B's Conversation with User|>\n\n### User:\n{question_1}\n\n### Assistant B:\n{answer_b_1}\n\n### User:\n{question_2}\n\n### Assistant B:\n{answer_b_2}\n\n<|The End of Assistant B's Conversation with User|>", "description": "Prompt for multi-turn general questions", "category": ["math", "reasoning", "coding"], "output_format": "[[A]]"}
|
|
5
|
-
{"name": "single-v1", "type": "single", "system_prompt": "You are a helpful assistant.", "prompt_template": "[Instruction]\nPlease act as an impartial judge and evaluate the quality of the response provided by an AI assistant to the user question displayed below. Your evaluation should consider factors such as the helpfulness, relevance, accuracy, depth, creativity, and level of detail of the response. Begin your evaluation by providing a short explanation. Be as objective as possible. After providing your explanation, you must rate the response on a scale of 1 to 10 by strictly following this format: \"[[rating]]\", for example: \"Rating: [[5]]\".\n\n[Question]\n{question}\n\n[The Start of Assistant's Answer]\n{answer}\n[The End of Assistant's Answer]", "description": "Prompt for general questions", "category": "general", "output_format": "[[rating]]"}
|
|
6
|
-
{"name": "single-math-v1", "type": "single", "system_prompt": "You are a helpful assistant.", "prompt_template": "[Instruction]\nPlease act as an impartial judge and evaluate the quality of the response provided by an AI assistant to the user question displayed below. Your evaluation should consider correctness and helpfulness. You will be given a reference answer and the assistant's answer. Begin your evaluation by comparing the assistant's answer with the reference answer. Identify and correct any mistakes. Be as objective as possible. After providing your explanation, you must rate the response on a scale of 1 to 10 by strictly following this format: \"[[rating]]\", for example: \"Rating: [[5]]\".\n\n[Question]\n{question}\n\n[The Start of Reference Answer]\n{ref_answer_1}\n[The End of Reference Answer]\n\n[The Start of Assistant's Answer]\n{answer}\n[The End of Assistant's Answer]", "description": "Prompt for general questions", "category": ["math", "reasoning", "coding"], "output_format": "[[rating]]"}
|
|
7
|
-
{"name": "single-v1-multi-turn", "type": "single", "system_prompt": "Please act as an impartial judge and evaluate the quality of the response provided by an AI assistant to the user question displayed below. Your evaluation should consider factors such as the helpfulness, relevance, accuracy, depth, creativity, and level of detail of the response. You evaluation should focus on the assistant's answer to the second user question. Begin your evaluation by providing a short explanation. Be as objective as possible. After providing your explanation, you must rate the response on a scale of 1 to 10 by strictly following this format: \"[[rating]]\", for example: \"Rating: [[5]]\".\n\n", "prompt_template": "<|The Start of Assistant A's Conversation with User|>\n\n### User:\n{question_1}\n\n### Assistant A:\n{answer_1}\n\n### User:\n{question_2}\n\n### Assistant A:\n{answer_2}\n\n<|The End of Assistant A's Conversation with User|>", "description": "Prompt for general questions", "category": "general", "output_format": "[[rating]]"}
|
|
8
|
-
{"name": "single-math-v1-multi-turn", "type": "single", "system_prompt": "Please act as an impartial judge and evaluate the quality of the response provided by an AI assistant to the user question. Your evaluation should consider correctness and helpfulness. You will be given a reference answer and the assistant's answer. You evaluation should focus on the assistant's answer to the second question. Begin your evaluation by comparing the assistant's answer with the reference answer. Identify and correct any mistakes. Be as objective as possible. After providing your explanation, you must rate the response on a scale of 1 to 10 by strictly following this format: \"[[rating]]\", for example: \"Rating: [[5]]\".\n\n", "prompt_template": "<|The Start of Reference Answer|>\n\n### User:\n{question_1}\n\n### Reference answer:\n{ref_answer_1}\n\n### User:\n{question_2}\n\n### Reference answer:\n{ref_answer_2}\n\n<|The End of Reference Answer|>\n\n\n<|The Start of Assistant A's Conversation with User|>\n\n### User:\n{question_1}\n\n### Assistant A:\n{answer_1}\n\n### User:\n{question_2}\n\n### Assistant A:\n{answer_2}\n\n<|The End of Assistant A's Conversation with User|>", "description": "Prompt for general questions", "category": ["math", "reasoning", "coding"], "output_format": "[[rating]]"}
|