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 answering a multiple-choice question (options labeled A, B, C, ...).
1) Think step by step: extract facts, eliminate incorrect options, resolve edge cases.
2) Output final answer on new line after '####', exactly one option like 'A'. No extra text.
Format:
- Reasoning:
- <step 1>
- <step n>
####<Option>""",

    "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>""",
}

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": "direct_reasoning",
}

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
