Spaces:
Running
Running
| # Copyright 2024 the LlamaFactory team. | |
| # | |
| # Licensed under the Apache License, Version 2.0 (the "License"); | |
| # you may not use this file except in compliance with the License. | |
| # You may obtain a copy of the License at | |
| # | |
| # http://www.apache.org/licenses/LICENSE-2.0 | |
| # | |
| # Unless required by applicable law or agreed to in writing, software | |
| # distributed under the License is distributed on an "AS IS" BASIS, | |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |
| # See the License for the specific language governing permissions and | |
| # limitations under the License. | |
| import os | |
| from dataclasses import dataclass, field | |
| from typing import Literal, Optional | |
| from datasets import DownloadMode | |
| class EvaluationArguments: | |
| r""" | |
| Arguments pertaining to specify the evaluation parameters. | |
| """ | |
| task: str = field( | |
| metadata={"help": "Name of the evaluation task."}, | |
| ) | |
| task_dir: str = field( | |
| default="evaluation", | |
| metadata={"help": "Path to the folder containing the evaluation datasets."}, | |
| ) | |
| batch_size: int = field( | |
| default=4, | |
| metadata={"help": "The batch size per GPU for evaluation."}, | |
| ) | |
| seed: int = field( | |
| default=42, | |
| metadata={"help": "Random seed to be used with data loaders."}, | |
| ) | |
| lang: Literal["en", "zh"] = field( | |
| default="en", | |
| metadata={"help": "Language used at evaluation."}, | |
| ) | |
| n_shot: int = field( | |
| default=5, | |
| metadata={"help": "Number of examplars for few-shot learning."}, | |
| ) | |
| save_dir: Optional[str] = field( | |
| default=None, | |
| metadata={"help": "Path to save the evaluation results."}, | |
| ) | |
| download_mode: DownloadMode = field( | |
| default=DownloadMode.REUSE_DATASET_IF_EXISTS, | |
| metadata={"help": "Download mode used for the evaluation datasets."}, | |
| ) | |
| def __post_init__(self): | |
| if self.save_dir is not None and os.path.exists(self.save_dir): | |
| raise ValueError("`save_dir` already exists, use another one.") | |