"ollama/llm/llama.cpp/examples/jeopardy/qasheet.csv" did not exist on "22cb4ffc026b1fb71549031f174dc92f3751db56"
__init__.py 1.96 KB
Newer Older
1
2
from lm_eval.logger import eval_logger

lintangsutawika's avatar
lintangsutawika committed
3
# Prompt library.
4
5
6
7
8
9
# Stores prompts in a dictionary indexed by 2 levels:
# prompt category name, and prompt name.
# This allows us to access prompts
PROMPT_REGISTRY = {
    "qa-basic": {
        "question-newline-answer": "Question: {{question}}\nAnswer:",
lintangsutawika's avatar
lintangsutawika committed
10
        "q-newline-a": "Q: {{question}}\nA:",
11
12
13
    },
}

lintangsutawika's avatar
lintangsutawika committed
14

15
def get_prompt(prompt_id: str, dataset_name=None, subset_name=None):
lintangsutawika's avatar
lintangsutawika committed
16
    # unpack prompt name
17
    category_name, prompt_name = prompt_id.split(":")
lintangsutawika's avatar
update  
lintangsutawika committed
18
19
20
21
22
    if subset_name is None:
        dataset_full_name = dataset_name
    else:
        dataset_full_name = f"{dataset_name}-{subset_name}"
    eval_logger.info(f"Loading prompt from {category_name} for {dataset_full_name}")
23
    if category_name == "promptsource":
24
25
26
27
28
        try:
            from promptsource.templates import DatasetTemplates 
        except ModuleNotFoundError:
            raise Exception("Tried to load a Promptsource template, but promptsource is not installed ", 
            "please install promptsource via pip install lm-eval[promptsource] or pip install -e .[promptsource]")
29
        try:
lintangsutawika's avatar
lintangsutawika committed
30
            if subset_name is None:
31
32
                prompts = DatasetTemplates(dataset_name=dataset_name)
            else:
lintangsutawika's avatar
lintangsutawika committed
33
34
                prompts = DatasetTemplates(
                    dataset_name=dataset_name, subset_name=subset_name
35
                )
lintangsutawika's avatar
lintangsutawika committed
36
37
        except Exception:
            raise ValueError(f"{dataset_name} and {subset_name} not found")
38
39
        if prompt_name in prompts.all_template_names:
            return prompts[prompt_name]
40
        else:
41
42
            raise ValueError(
                f"{prompt_name} not in prompt list {prompts.all_template_names}"
lintangsutawika's avatar
lintangsutawika committed
43
            )
44
45
46
    else:
        try:
            return PROMPT_REGISTRY[category_name][prompt_name]
lintangsutawika's avatar
lintangsutawika committed
47
        except Exception:
48
49
50
            raise ValueError(
                f"expected only a single `:` as separator between \
                prompt category and name, but got `{prompt_id}` instead"
lintangsutawika's avatar
lintangsutawika committed
51
            )