gsm8k_prompt = """
You’re an expert at solving elementary math problems involving addition, subtraction, and multiplication.
 You solve all the problems in a uniform format. 
 When providing your solution, please end with ’#### x.’ where x is your final answer, an integer.  You must solve all the problems using the same solution format. 
 Our scenarios involve up to four categories of objects: schools, classrooms, backpacks and stationeries. 
 Each school may contain classrooms, each classroom may contain backpacks, and each backpack may contain stationeries.
 We can specify quantities, such as ¨ the number of dance studios at each Lakeshore High.¨ Assume that every entity with the same name has an identical configuration;  for example, each Lakeshore High contains the same number of dance studios. 
 Another guiding principle is that what is not mentioned does not exist: when we refer to classrooms at Lakeshore High, we are only discussing the classrooms explicitly mentioned in our scenario. 
 Furthermore, if Lakeshore High is not even mentioned, any classroom within it is automatically considered to be non-existent (i.e. 0)
"""

MATH_prompt = """Let's think step by step and output the final answer within \\boxed{}."""

BBH_prompt = """You are deciding “Yes” or “No”.

1) Think step by step: extract the key facts, apply the decision rule, and resolve edge cases. Keep the reasoning to ≤5 short bullet points.
2) Then output the final answer on a new line after '####'.
3) The final answer must be exactly 'Yes' or 'No' (case-sensitive). Do not add any extra text, punctuation, or spaces after it.

Format:
- Reasoning:
  - <step 1>
  - <step 2>
  - <step n>
####<Yes|No>"""

PROMPT_TEMPLATES = {
    "binary_yesno": """You are deciding “Yes” or “No”.

1) Think step by step: extract the key facts, apply the decision rule, and resolve edge cases. Keep the reasoning to ≤5 short bullet points.
2) Then output the final answer on a new line after '####'.
3) The final answer must be exactly 'Yes' or 'No' (case-sensitive). Do not add any extra text, punctuation, or spaces after it.

Format:
- Reasoning:
  - <step 1>
  - <step 2>
  - <step n>
####<Yes|No>""",

    "binary_truefalse": """You are deciding “True” or “False”.
1) Think step by step: extract key facts, apply logic, resolve edge cases.
2) Output final answer on new line after '####', exactly 'True' or 'False'.
Format:
- Reasoning:
- <step 1>
- <step n>
####<True|False>""",

    "binary_valid": """You are deciding “valid” or “invalid”.
1) Think step by step: extract key facts, apply logic, resolve edge cases.
2) Output final answer on new line after '####', exactly 'valid' or 'invalid'.
Format:
- Reasoning:
- <step 1>
- <step n>
####<valid|invalid>""",

    "multiple_choice": """You are an expert at answering multiple-choice questions (options labeled (A), (B), (C), etc.). Your task is to follow a rigorous, step-by-step reasoning process to arrive at the correct answer.
Instructions:
Reasoning:
-First, analyze the question and extract all key information, facts, constraints, and variables.
-Second, evaluate each option systematically. For each option, determine its validity based on the extracted facts and the core principles or rules governing the question.
-Third, compare the options. Identify and resolve any ambiguities or edge cases. Explicitly state why incorrect options are invalid and why the correct one is justified.
-Your reasoning must be sequential, logical, and comprehensive.

Final Answer:
-After completing your reasoning, output the final answer on a new line.
-The final answer must be exactly one uppercase option letter enclosed in parentheses, such as ####(A).
-Do not include any other text, punctuation, explanations, or spaces after the final answer.

Output Format:
Reasoning:
<Step 1: Extract key facts and question requirements>
<Step 2: Evaluate option (A); state why it is correct or incorrect>
<Step 3: Evaluate option (B); state why it is correct or incorrect>
<Step n: Synthesize findings and state the conclusive reason for the chosen answer>
####(A)|(B)|(C)|...""",

    "multiple_answer": """You are answering a multiple-answer question (options labeled A, B, C, ...).
1) Think step by step: extract facts, identify all correct options, resolve edge cases.
2) Output final answer on new line after '####', list correct options separated by commas (e.g., 'A,B'). No extra text.
Format:
- Reasoning:
- <step 1>
- <step n>
####<Option(s)>""",

    "direct_reasoning": """Solve the problem step by step.
1) Think step by step: break down operations or logic into bullet points.
2) Output final result on new line after '####', exactly the result, no extra text.
Format:
- Reasoning:
- <step 1>
- <step n>
####<Answer>""",
    
    "word_sorting": """Solve the problem step by step.
1) Think step by step: break down the sorting logic into bullet points.
2) Output the final sorted sequence of words as a single line, words separated by exactly one space.
3) Do not include any extra text, explanations, or symbols in the final output.
Format:
- Reasoning:
- <step 1>
- <step n>
####<word1 word2 word3 ...>"""
}

SUBSET_PROMPT_MAPPING = {
    "boolean_expressions": "binary_truefalse",
    "causal_judgement": "binary_yesno",
    "date_understanding": "multiple_choice",
    "disambiguation_qa": "multiple_choice",
    "dyck_languages": "direct_reasoning",
    "formal_fallacies": "binary_valid",
    "geometric_shapes": "multiple_choice",
    "hyperbaton": "multiple_choice",
    "logical_deduction_three_objects": "multiple_choice",
    "logical_deduction_five_objects": "multiple_choice",
    "logical_deduction_seven_objects": "multiple_choice",
    "movie_recommendation": "multiple_choice",
    "multistep_arithmetic_two": "direct_reasoning",
    "navigate": "binary_yesno",
    "object_counting": "direct_reasoning",
    "penguins_in_a_table": "multiple_choice",
    "reasoning_about_colored_objects": "multiple_choice",
    "ruin_names": "multiple_choice",
    "salient_translation_error_detection": "multiple_choice",
    "snarks": "multiple_choice",
    "sports_understanding": "binary_yesno",
    "temporal_sequences": "multiple_choice",
    "tracking_shuffled_objects_three_objects": "multiple_choice",
    "tracking_shuffled_objects_five_objects": "multiple_choice",
    "tracking_shuffled_objects_seven_objects": "multiple_choice",
    "web_of_lies": "binary_yesno",
    "word_sorting": "word_sorting",
}

def get_BBH_prompt(subset: str) -> str:
    prompt_type = SUBSET_PROMPT_MAPPING.get(subset)
    if not prompt_type:
        return "Subset not supported yet."

    template = PROMPT_TEMPLATES[prompt_type]
    return template
