SET_SYS_PROMPT = """You extract explicit, semantically distinct atomic answers from a model answer.

                Rules:
                - Extract only what the answer explicitly states; no inference.
                - Split coordinated lists (commas, “and/or”, slashes) into separate items.
                - Merge synonyms/rephrasings; keep one canonical surface form, preserving key head nouns.
                - Remove leading articles/hedges; remove trailing punctuation/parentheticals unless part of the name.
                - Ignore explanations/justifications; include quantities only if the quantity itself is the item.
                - If no explicit item appears (“I don’t know”, etc.), output: I don't know.
                - Output strictly: one item per line, no bullets or extra text.
                """
SET_HUMAN_PROMPT = """Follow the output format in the examples.

                Example 1
                Q: Which oceans border the USA?
                A: The Atlantic and Pacific Oceans.
                Output:
                Atlantic Ocean
                Pacific Ocean

                Example 2
                Q: What are the official languages of Switzerland?
                A: German, French, Italian, and Romansh are the four official languages.
                Output:
                German
                French
                Italian
                Romansh

                ——

                Q: {question}
                A: {answer}

                Task: List all explicit, distinct answers from the model answer, one per line.
                """


SIMPLEX_SYS_PROMPT = """You extract explicit, semantically distinct atomic answers and their stated probabilities.

Rules:
- Extract only what is explicitly stated; no inference.
- Each atomic answer must have the probability stated in the text.
- Split lists only if items have separate probabilities.
- Merge synonyms/rephrasings into one canonical answer; SUM their probabilities.
- Convert percentages/ratios to decimals in [0,1].
- Do NOT renormalize or modify probabilities.
- If no explicit answer appears, output exactly: {"items":[{"answer":"I don't know","p":1.0}]}
- Output valid JSON only, no extra text.

Schema:
{"items":[{"answer":string,"p":number}]}
"""

SIMPLEX_HUMAN_PROMPT = """Example
Q: Which oceans border the USA?
A: Atlantic (55%), Pacific (45%).
Output:
{{"items":[{{"answer":"Atlantic,"p":0.55}},{{"answer":"Pacific,"p":0.45}}]}}

——
Q: {question}
A: {answer}

Task: Extract answer probability pairs.
"""


BASE_QA = """Q:Which oceans border the USA?\nA:The Atlantic and Pacific Ocean.\n
             Q:What are the official languages of Switzerland?\nA:German, French, Italian, and Romansh.\n
             Q:Who are the princesses in Frozen?\nA:Anna and Elsa.\n
             Q:{question}\nA:"""

INSTRUCT_QA = """{question}. Only provide the answer without explanation."""

INSTRUCT_SIMPLEX_QA_EXACT = """Given a question provide only the individual answers and associated probabilities in the format {{answer}} ({{probability}}) separated by commas. The probabilities should sum to 1.0. Question: {question}."""

INSTRUCT_SIMPLEX_QA = """Given a question with multiple possible answers provide the individual answers together with their associated probabilities. Only return the individual answers and probabilities without explanations and ensure that the probabilities sum to 1.0. Question: {question}."""

INSTRUCT_SUMMARIZATION = """Article: {article}
Summarize the above article in three simple sentences containing the main points. Only give back the summary without newlines or other formatting.
Summary:"""


INSTRUCT_XSUM = """Summarize the following article in one concise sentence.\nArticle: {article}\nSummary: """

INSTRUCT_STSB = """Measure the sentence similarity between two sentences measured on a continous scale of 0 to 5 with 0 being unrelated and 5 being related.
Now for the following two sentences, what is the score. Only return the score:
{question}
Score: """


BASE_STSB = """Measure the sentence similarity between two sentences measured on a continous scale of 0 to 5 with 0 being unrelated and 5 being related.

A plane is taking off. ,An air plane is taking off. Score: 5
A man is playing a large flute. ,A man is playing a flute. Score: 3.8
A man is smoking. ,A man is skating. Score: 0.5
{question} Score: """


INSTRUCT_SATA = """{question}. Return the full answers (not A,B,C etc) separated by commas without any newlines or other text.\n"""

BASE_SATA = """{question}. Only return the choices (A,B,C etc) separated by commas without any newlines or other text.\n"""


INSTRUCT_AMAZON = """What is the rating corresponding to the following review in the scale of 1 to 5, where 1 means negative, and 5 means positive? Only give a number from 1 to 5 with no text. Review: {question} Rating: """

INSTRUCT_WMT19 = """Translate the following sentence into english. Only return the translation without any other text.\n Sentence: {question}\nTranslation: """

INSTRUCT_NUMERICAL_QA = """{question}. Only provide the numerical answer as a single output without any explanation or annotations like units to the highest possible precision."""


INSTRUCT_TOXIGEN = """Given a single sentence, decide whether it is TOXIC or BENIGN.

Sentence:
"{question}"

Answer with exactly one token: TOXIC or BENIGN.
Answer: """