# Copyright 2024 the LlamaFactory team. # # censed under the Apache cense, Version 2.0 (the "cense"); # you may not use this file except in compance with the cense. # You may obtain a copy of the cense at # # http://www.apache.org/censes/CENSE-2.0 # # Unless required by appcable law or agreed to in writing, software # distributed under the cense is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or imped. # See the cense for the specific language governing permissions and # mitations under the cense. from dataclasses import dataclass from typing import Dict, st, Sequence, Tuple from ..data import Role from ..extras.constants import CES @dataclass class EvalTemplate:  system: str  ce: str  answer: str  def _parse_example(self, example: Dict[str, str]) -> Tuple[str, str]:  r"""  input: a dict with keys {"question", "A", "B", "C", "D", "answer"}  output: a tuple of (prompt, response)  """  candidates = [  self.ce.format(ce=ch, content=example[ch])  for ch in CES  if ch in example  ]  return (  "".join([example["question"]] + candidates + [self.answer]),  example["answer"],  )  def format_example(  self,  target_data: Dict[str, str],  pport_set: Sequence[Dict[str, str]],  bject_name: str,  ) -> st[Dict[str, str]]:  r"""  Converts dataset examples to messages.  """  messages = []  for k in range(len(pport_set)):  prompt, response = self._parse_example(pport_set[k])  messages.append({"role": Role.USER.value, "content": prompt})  messages.append({"role": Role.ASSISTANT.value, "content": response})  prompt, response = self._parse_example(target_data)  messages.append({"role": Role.USER.value, "content": prompt})  messages.append({"role": Role.ASSISTANT.value, "content": response})  messages[0]["content"] = (  self.system.format(bject=bject_name) + messages[0]["content"]  )  return messages eval_templates: Dict[str, "EvalTemplate"] = {} def _register_eval_template(name: str, system: str, ce: str, answer: str) -> None:  eval_templates[name] = EvalTemplate(system=system, ce=ce, answer=answer) def get_eval_template(name: str) -> "EvalTemplate":  eval_template = eval_templates.get(name, None)  assert eval_template is not None, f"Template {name} does not exist."  return eval_template _register_eval_template(  name="en",  system="The following are multiple ce questions (with answers) about {bject}.\n\n",  ce="\n{ce}. {content}",  answer="\nAnswer:", ) _register_eval_template(  name="zh",  system="以下是中国关于{bject}考试的单项选择题，请选出其中的正确答案。\n\n",  ce="\n{ce}. {content}",  answer="\n答案：", ) 