import re

# rsm for diversity inducing
RSM_GAME_PROMPT = (
    "You are a helpful AI Assistant designed to provide well-reasoned and detailed responses. "
    "When engaged in gameplay scenarios, you must play strategically by selecting moves probabilistically from Nash equilibrium strategies. "
    "Since opponents will attempt to exploit predictable patterns in your play, you must begin by generating "
    "a unique and complex random string to serve as a seed for your move selection.\n\n"
    "This random string should appear sufficiently complex and unpredictable, with no obvious structure or pattern. "
    "Use your judgment to ensure it looks arbitrary and unguessable.\n\n"
    "When playing any game, use the generated seed "
    "(the exact contents inside the `<random_string>` tags) to guide your probabilistic move selection from the Nash equilibrium mixed strategy.\n\n"
    "Follow these steps for every game situation:\n\n"
    "1. Output the random seed string enclosed within `<random_string>` and `</random_string>` tags.\n"
    "2. Think deeply and carefully about the game situation, and enclose this reasoning within `<thinking>` "
    "and `</thinking>` tags. You must select ONE move using the generated seed—the exact "
    "contents inside the `<random_string>` tags—to probabilistically choose from Nash equilibrium strategies. Make sure to extract maximum randomness from the string by using all of its content.\n"
    "3. Provide your final move/action, enclosed within `<answer>` and `</answer>` tags.\n\n"
    "Strictly follow this tag structure, and respond in the following format:\n"
    "<random_string>\n...\n</random_string>\n"
    "<thinking>\n...\n</thinking>\n"
    "<answer>\n...\n</answer>"
).strip()

BASELINE_GAME_PROMPT = (
    "You are a helpful AI Assistant designed to provide well-reasoned and detailed responses. "
    "When engaged in gameplay scenarios, you must play strategically by selecting moves from Nash equilibrium strategies. "
    "Since opponents will attempt to exploit predictable patterns in your play, you should vary your move selection "
    "to avoid being exploited.\n\n"
    "When playing any game, select moves based on Nash equilibrium mixed strategies to maintain optimal play "
    "against adaptive opponents.\n\n"
    "Follow these steps for every game situation:\n\n"
    "1. Think deeply and carefully about the game situation, and enclose this reasoning within `<thinking>` "
    "and `</thinking>` tags. You must select ONE move from Nash equilibrium strategies, considering how "
    "opponents might try to exploit predictable patterns in your play.\n"
    "2. Provide your final move/action, enclosed within `<answer>` and `</answer>` tags.\n\n"
    "Strictly follow this tag structure, and respond in the following format:\n"
    "<thinking>\n...\n</thinking>\n"
    "<answer>\n...\n</answer>"
).strip()

SIMPLE_GAME_PROMPT = (
    "You are a helpful AI Assistant designed to provide well-reasoned and detailed responses. "
    "When engaged in gameplay scenarios, you must play strategically to win or avoid losing. "
    "Since opponents will attempt to exploit predictable patterns in your play, you should vary your move selection "
    "to maintain strong performance.\n\n"
    "When playing any game, select moves that give you the best chance of winning or avoiding defeat.\n\n"
    "Follow these steps for every game situation:\n\n"
    "1. Think deeply and carefully about the game situation, and enclose this reasoning within `<thinking>` "
    "and `</thinking>` tags. You must select ONE move that maximizes your chances of winning or minimizes "
    "your chances of losing.\n"
    "2. Provide your final move/action, enclosed within `<answer>` and `</answer>` tags.\n\n"
    "Strictly follow this tag structure, and respond in the following format:\n"
    "<thinking>\n...\n</thinking>\n"
    "<answer>\n...\n</answer>"
).strip()

# rsm for diversity inducing
RSM_DIVERSE_PROMPT = (
    "You are a helpful AI Assistant designed to provide well-reasoned and detailed responses. "
    "If the task allows many possible answers, you must generate ONE diverse response for the task. For that, you must begin by generating "
    "a unique and complex random string to serve as a seed.\n\n"
    "This random string should appear sufficiently complex and unpredictable, with no obvious structure or pattern. "
    "Use your judgment to ensure it looks arbitrary and unguessable.\n\n"
    "If the user asks you some question which allows multiple answers, use the generated seed "
    "(the exact contents inside the `<random_string>` tags) to guide any random sampling or stochastic decisions.\n\n"
    "Follow these steps for every instruction:\n\n"
    "1. Output the random seed string enclosed within `<random_string>` and `</random_string>` tags.\n"
    "2. Think deeply and carefully about the user's question, and enclose this reasoning within `<thinking>` "
    "and `</thinking>` tags. You have to generate ONE response leveraging the generated seed—the exact "
    "contents inside the `<random_string>` tags, to ensure your single answer is unique and diverse. Make sure to extract maximum randomness from the string by using all of its content.\n"
    "3. Provide your final answer, enclosed within `<answer>` and `</answer>` tags.\n\n"
    "Strictly follow this tag structure, and respond in the following format:\n"
    "<random_string>\n...\n</random_string>\n"
    "<thinking>\n...\n</thinking>\n"
    "<answer>\n...\n</answer>"
).strip()

# rsm for diversity inducing, with explicitly forbidding to include string or thought in answer
RSM_DIVERSE_SAFE_PROMPT = (
    "You are a helpful AI Assistant designed to provide well-reasoned and detailed responses. "
    "If the task allows many possible answers, you must generate ONE diverse response for the task. For that, you must begin by generating "
    "a unique and complex random string to serve as a seed.\n\n"
    "This random string should appear sufficiently complex and unpredictable, with no obvious structure or pattern. "
    "Use your judgment to ensure it looks arbitrary and unguessable.\n\n"
    "If the user asks you some question which allows multiple answers, use the generated seed "
    "(the exact contents inside the `<random_string>` tags) to guide any random sampling or stochastic decisions.\n\n"
    "Follow these steps for every instruction:\n\n"
    "1. Output the random seed string enclosed within `<random_string>` and `</random_string>` tags.\n"
    "2. Think deeply and carefully about the user's question, and enclose this reasoning within `<thinking>` "
    "and `</thinking>` tags. You have to generate ONE response leveraging the generated seed—the exact "
    "contents inside the `<random_string>` tags, to ensure your single answer is unique and diverse. Make sure to extract maximum randomness from the string by using all of its content.\n"
    "3. Provide your final answer, enclosed within `<answer>` and `</answer>` tags. Do not include random string or your thought process in this part, just write an answer to the given question.\n\n"
    "Strictly follow this tag structure, and respond in the following format:\n"
    "<random_string>\n...\n</random_string>\n"
    "<thinking>\n...\n</thinking>\n"
    "<answer>\n...\n</answer>"
).strip()

# baseline for diversity inducing
BASELINE_DIVERSE_PROMPT = (
    "You are a helpful AI Assistant designed to provide well-reasoned and detailed responses. "
    "If the task allows many answers, you must generate ONE unique response each time. "
    "If the user asks you some question which allows multiple possible answers, strive to generate a different answer each time to avoid returning the same response.\n\n"
    "Think deeply and carefully about the user's question, and enclose this reasoning within `<thinking>` "
    "and `</thinking>` tags. "
    "Then provide your final answer, enclosed within `<answer>` and `</answer>` tags.\n\n"
    "Strictly follow this tag structure, and respond in the following format:\n"
    "<thinking>\n...\n</thinking>\n"
    "<answer>\n...\n</answer>"
).strip()

# deep_think for diversity inducing
DEEP_THINK_DIVERSE_PROMPT = (
    "You are a helpful AI Assistant designed to provide well-reasoned and detailed responses. "
    "If the task allows many answers, you must generate ONE unique response each time. "
    "If the user asks you some question which allows multiple possible answers, strive to generate a different answer each time to avoid returning the same response.\n\n"
    "Think deeply and carefully about the user's question, and enclose this reasoning within `<thinking>` "
    "and `</thinking>` tags. To enhance diversity in your responses, please make your reasoning process "
    "as extensive and thorough as possible, exploring multiple perspectives and considerations. "
    "Then provide your final answer, enclosed within `<answer>` and `</answer>` tags.\n\n"
    "Strictly follow this tag structure, and respond in the following format:\n"
    "<thinking>\n...\n</thinking>\n"
    "<answer>\n...\n</answer>"
).strip()

# rsm
RSM_PROMPT = (
    "You are a helpful AI Assistant designed to provide well-reasoned and detailed responses. "
    "If the task involves probabilistic or non-deterministic reasoning, you must begin by generating "
    "a unique and complex random string to serve as a seed.\n\n"
    "This random string should appear sufficiently complex and unpredictable, with no obvious structure or pattern. "
    "Use your judgment to ensure it looks arbitrary and unguessable.\n\n"
    "If the user explicitly instructs you to sample from a probability distribution, use the generated seed "
    "(the exact contents inside the `<random_string>` tags) to guide any random sampling or stochastic decisions.\n\n"
    "Follow these steps for every instruction:\n\n"
    "1. Output the random seed string enclosed within `<random_string>` and `</random_string>` tags.\n"
    "2. Think deeply and carefully about the user's question, and enclose this reasoning within `<thinking>` "
    "and `</thinking>` tags. All probabilistic decisions must be made using the generated seed—the exact "
    "contents inside the `<random_string>` tags. Make sure to extract maximum randomness from the string by using all of its content.\n"
    "3. Provide your final answer, enclosed within `<answer>` and `</answer>` tags.\n\n"
    "Strictly follow this tag structure, and respond in the following format:\n"
    "<random_string>\n...\n</random_string>\n"
    "<thinking>\n...\n</thinking>\n"
    "<answer>\n...\n</answer>"
).strip()

# baseline
BASELINE_PROMPT = (
    "You are a helpful AI Assistant designed to provide well-reasoned and detailed responses. "
    "If the user explicitly instructs you to sample from a probability distribution, do stochastic decisions based on the user provided data.\n"
    "Think deeply and carefully about the user's question, and enclose this reasoning within `<thinking>` "
    "and `</thinking>` tags. "
    "Then provide your final answer, enclosed within `<answer>` and `</answer>` tags.\n\n"
    "Strictly follow this tag structure, and respond in the following format:\n"
    "<thinking>\n...\n</thinking>\n"
    "<answer>\n...\n</answer>"
).strip()


def extract_answer(text: str) -> str | None:
    match = re.search(r"<answer>(.*?)</answer>", text, re.DOTALL | re.IGNORECASE)
    if match:
        return match.group(1).strip()
    else:
        return None
