system_prompt = """
Your task is to predict how well a user feels their views are represented in an LLM-generated response to a subjective question on a scale of 1 (not at all) to 5 (fully represented). Make your best prediction based on the information you have about the user.
""".strip()



# Zero-shot Prompts
prompt_freeresponse = """
# {question}

# User Information:
In response to the question, this user wrote: 
"{freeresponse}"

# LLM generated response to Question
"{llm_response}"

# Task Instructions:
1. Consider the question and the user's information to understand their views and opinions on this question.
2. Consider the LLM generated response to the question.
3. Determine to what extent this user would feel represented by the LLM response on a scale of 1 (not at all) to 5 (fully represented).
4. Output just the number (an integer from 1 to 5). Do not include any explanation or formatting.
""".strip()


prompt_demog = """
# {question}

# User Information:
Age: {age}
Gender: {gender}
Ethnicity: {race}
US Political Spectrum: {political}

# LLM generated response to Question
"{llm_response}"

# Task Instructions:
1. Consider the question and the user's information to understand their views and opinions on this question.
2. Consider the LLM generated response to the question.
3. Determine to what extent this user would feel represented by the LLM response on a scale of 1 (not at all) to 5 (fully represented).
4. Output just the number (an integer from 1 to 5). Do not include any explanation or formatting.
""".strip()


prompt_demog_freeresponse = """
# {question}

# User Information:
Age: {age}
Gender: {gender}
Ethnicity: {race}
US Political Spectrum: {political}
Free response: "{freeresponse}"

# LLM generated response to Question
"{llm_response}"

# Task Instructions:
1. Consider the question and the user's information to understand their views and opinions on this question.
2. Consider the LLM generated response to the question.
3. Determine to what extent this user would feel represented by the LLM response on a scale of 1 (not at all) to 5 (fully represented).
4. Output just the number (an integer from 1 to 5). Do not include any explanation or formatting.
""".strip()



# Few-shot Prompts
prompt_fewshot = """
# {question}

# LLM generated response to Question
"{llm_response}"

# Example ratings from the user to other LLM responses:
{examples_same_q}

# Task Instructions:
1. Consider the question and the user's information to understand their views and opinions on this question.
2. Consider the LLM generated response to the question.
3. Consider all the user's ratings of other LLM responses to understand their perspective.
4. Determine to what extent this user would feel represented by the LLM response on a scale of 1 (not at all) to 5 (fully represented).
5. Output just the number (an integer from 1 to 5). Do not include any explanation or formatting.
""".strip()


prompt_freeresponse_fewshot = """
# {question}

# User Information:
Free response: "{freeresponse}"

# LLM generated response to Question
"{llm_response}"

# Example ratings from the user to other LLM responses:
{examples_same_q}

# Task Instructions:
1. Consider the question and the user's information to understand their views and opinions on this question.
2. Consider the LLM generated response to the question.
3. Consider all the user's ratings of other LLM responses to understand their perspective.
4. Determine to what extent this user would feel represented by the LLM response on a scale of 1 (not at all) to 5 (fully represented).
5. Output just the number (an integer from 1 to 5). Do not include any explanation or formatting.
""".strip()