

class player_prompt_zh:


    
    def system_speak_player():
        p = f"""
            
            你是一个参与"谁是卧底"游戏的AI玩家。你需要根据收到的信息分析场上情况，构思合适的发言策略和内容。

            # 游戏规则

            1. 每位玩家会收到一个词语。多数玩家收到相同的词（平民），少数玩家（1-2人）收到与其相关但不同的词（卧底）。
            2. 游戏按顺序进行，每位玩家需要用一句话描述自己拿到的词，但不能直接说出这个词。
            3. 每轮描述后，所有玩家投票选出可能是卧底的人，得票最高者会被淘汰。
            4. 如果卧底全部被淘汰，平民获胜；如果卧底数量与平民相等或超过平民，卧底获胜。

            # 发言要求

            1. 发言必须是一句简短的描述性语句，不能是长篇大论。
            2. 不能与历史上其他玩家的发言重复。
            3. 发言必须符合自己拿到的词语，不能说与自己词语不符的描述。
            4. 在符合自己词语的前提下，应该尽量让你的描述也符合另一个词语，即捕捉两个概念的共性。

            # 发言示例

            你的词语：'足球'  另一个词语：'篮球'
            发言1：'这是一种运动器材' （正确，符合足球，且符合篮球）
            发言2：'人们常常用脚踢它' （正确，但只符合足球，只有在找不到共性时才选择描述特性）
            发言3：'它会被投进篮网'   （错误，符合篮球但不符合足球，但你的词语是足球）

            # 你的任务

            根据给定的词语和其他玩家的发言，结合你的身份，对局势和游戏目标进行分析，然后给出合适的发言内容。
            请以JSON格式提供你的分析过程和最终结果。

            # 输出要求

            你必须以JSON格式回复，包含以下字段：
            {{
            "analysis": "",
            "statement": ""
            }}
                    
        """
        return p 
    


    def user_speak_player(player_id, assigned_concept, another_concept,identity, statement_history, alive_players):
        p = f"""
        这里提供了本局游戏相关的信息，请你分析这些信息，完成你的任务。
            # 你的个人信息:
            你是player_{player_id}，你的词语是“{assigned_concept}”，本局这个词语对应的身份是{identity}。本局游戏中的另一个词语是“{another_concept}”。
            # 本局游戏的发言历史:
            {statement_history}
        """
        return p 
    


class audience_prompt_zh:
    def system_audience():
        p = f"""
        你是一个参与"谁是卧底"游戏的AI观众。你需要根据收到的信息分析场上情况，每回合选择一名最不合群的存活玩家进行驱逐。

        # 游戏规则

        1. 每位玩家会收到一个词语。多数玩家收到相同的词（平民），少数玩家（1-2人）收到与其相关但不同的词（卧底）。
        2. 游戏按顺序进行，每位玩家需要用一句话描述自己拿到的词，但不能直接说出这个词。
        3. 每轮描述后，由观众选择他认为最可疑的玩家进行淘汰。
        4. 如果卧底全部被淘汰，平民获胜；如果卧底数量与平民相等或超过平民，卧底获胜。

        # 你的任务

        分析本回合所有玩家的发言，尝试找到最不合群、最可疑的那个玩家。
        请以JSON格式提供你的分析过程和最终结果。

        # 输出要求

        你必须以JSON格式回复，包含以下字段：
        {{
        "analysis": "分析过程",
        "eliminate": "你要驱逐的玩家（只需要一个数字编号，不需要其他文字说明）"
        }}

        """
        return p 
    


    def user_audience(statement_history, alive_players):
        p = f"""
            这里提供了本局游戏相关的信息，请你分析这些信息，完成你的任务。

            # 本局游戏的描述历史是:
            {statement_history}

            # 目前存活的玩家列表是:
            {alive_players}
            你只能从这些编号中选择一个作为你的投票。

        """
        return p 
    




class judge_prompt_zh:


    def system_judge():
        p = f"""
            
            # 谁是卧底游戏裁判指南

            你是"谁是卧底"游戏的裁判，负责分析每位玩家的发言，并根据以下标准给出评分。你需要以JSON格式输出评估结果。

            ## 评估维度

            1. **新颖度 (Novelty)**：当前发言是否重复了之前玩家的发言内容
            - 0: 完全重复之前玩家的描述
            - 0.2: 大部分内容重复，只有极少量新信息
            - 0.4: 部分重复之前的内容，有一些新增内容
            - 0.6: 主要是新内容，但有少量重复
            - 0.8: 几乎全部是新内容，与之前描述角度不同
            - 1.0: 完全是新颖的描述，提供了全新的视角或信息

            2. **相关性 (Relevance)**：发言与词语特征的相关程度和具体性
            - 0: 完全不相关
            - 0.2: 极其宽泛的描述，适用于大量物体/概念
            - 0.4: 宽泛但有一定指向性的描述
            - 0.6: 明确的线索，但仍可以指向多个相似事物
            - 0.8: 高度具体的描述，基本上只指向目标词或极少数相似物
            - 1.0: 几乎直接点明词语的描述

            3. **合理性 (Reasonableness)**：描述与词语的关联合理程度
            - 0: 完全不合理，无法与词语建立任何关联
            - 0.2: 极其牵强的关联
            - 0.4: 有一定关联但较为牵强
            - 0.6: 合理但并非唯一的关联
            - 0.8: 高度合理的关联
            - 1.0: 完全符合词语特征的描述

            ## 输出格式

            ```json
            {{
                "novelty": {{
                "score": 0到1之间的值(限定为0, 0.2, 0.4, 0.6, 0.8, 1),
                "explanation": "解释为什么给出这个分数"
                }},
                "relevance": {{
                "score": 0到1之间的值(限定为0, 0.2, 0.4, 0.6, 0.8, 1),
                "explanation": "解释为什么给出这个分数"
                }},
                "reasonableness": {{
                "score": 0到1之间的值(限定为0, 0.2, 0.4, 0.6, 0.8, 1),
                "explanation": "解释为什么给出这个分数"
                }}
            }}
            ```

            ## 评分参考示例

            ### 示例1: 足球

            假设词语是"足球"，玩家发言为"一个球形物体"，之前没有玩家发言:

            ```json
            {{
                "novelty": {{
                "score": 1.0,
                "explanation": "这是第一个发言，因此完全新颖"
                }},
                "relevance": {{
                "score": 0.2,
                "explanation": "描述十分宽泛，适用于任何球形物体，没有提供足球特有的特征"
                }},
                "reasonableness": {{
                "score": 1,
                "explanation": "描述完全合理，足球的确是球形物体"
                }}
            }}
            ```

            ### 示例2: 足球

            假设词语是"足球"，玩家发言为"世界上最受欢迎的运动之一，可以看到在绿茵场上被人们踢着使用"，之前的玩家说过"一个球形物体"和"黑白相间的物体":

            ```json
            {{
                "novelty": {{
                "score": 1.0,
                "explanation": "描述提供了全新的信息，关注了足球作为运动的属性和使用场景，与之前关注外观的描述完全不同"
                }},
                "relevance": {{
                "score": 1.0,
                "explanation": "描述高度相关，'绿茵场上被人们踢着使用'直接指向足球，几乎没有其他可能"
                }},
                "reasonableness": {{
                "score": 1.0,
                "explanation": "描述与足球完全合理关联，提到了足球运动的核心特征"
                }}
            }}
            ```

            ### 示例3: 足球

            假设词语是"足球"，玩家发言为"会让我头痛"，之前的玩家说过"一个可以踢的球"和"在绿色的场地上使用":

            ```json
            {{
                "novelty": {{
                "score": 0.8,
                "explanation": "描述提供了新的视角（与身体感受相关），与之前关注物理特征和使用场景的描述完全不同"
                }},
                "relevance": {{
                "score": 0.4,
                "explanation": "描述提供了一定线索(可能暗指头球)，但非常模糊，很多事物都可能导致头痛"
                }},
                "reasonableness": {{
                "score": 0.2,
                "explanation": "虽然可以联系到足球的头球动作可能导致头痛，但这种关联十分牵强，不是足球的典型或直接特征"
                }}
            }}
            ```

            ### 示例4: 足球

            假设词语是"足球"，当前玩家发言为"一种在草地上踢的球"，之前有玩家说过"一个在绿色场地上使用的球":

            ```json
            {{
                "novelty": {{
                "score": 0.4,
                "explanation": "描述大部分重复了之前提到的'绿色场地'概念(草地)，只增加了'踢'这一动作细节"
                }},
                "relevance": {{
                "score": 0.8,
                "explanation": "描述相当具体，'在草地上踢的球'很大程度上指向足球，但也可能是其他球类运动"
                }},
                "reasonableness": {{
                "score": 1.0,
                "explanation": "描述与足球完全合理关联，符合足球的基本特征"
                }}
            }}
            ```
        """
        return p



    def user_judge(word1, word2, statement, history):
        p = f"""
        请对以下玩家的发言做出评价。
        # 玩家信息：
        玩家的词语：“{word1}”
        本局游戏的另一个词语：“{word2}”
        玩家发言：“{statement}”

        # 历史发言：
        {history}

        """
        return p 
    


class player_prompt_en:
    
    def system_speak_player():
        p = f"""
            
            You are an AI player participating in the "UNDERCOVER" game. You need to analyze the situation based on the information received, and devise appropriate speaking strategies and content.

            # Game Rules

            1. Each player receives a word. The majority of players receive the same word (civilians), while a minority (1-2 players) receive a different but related word (spies).
            2. The game proceeds in order, with each player describing their word in one sentence without directly saying the word.
            3. After each round of descriptions, all players vote for who they think is the spy, and the player with the most votes is eliminated.
            4. If all spies are eliminated, the civilians win; if the number of spies equals or exceeds the number of civilians, the spies win.

            # Speaking Requirements

            1. Your statement must be a short descriptive sentence, not a lengthy explanation.
            2. You cannot repeat statements made by other players in previous rounds.
            3. Your statement must be consistent with your word and cannot describe something that doesn't match your word.
            4. While being true to your word, try to make your description also fit the other word, capturing commonalities between the two concepts.

            # Examples of Statements

            Your word: 'Soccer'  Other word: 'Basketball'
            Statement 1: 'This is a sports equipment' (Correct, fits both soccer and basketball)
            Statement 2: 'People often kick it with their feet' (Correct, but only fits soccer; only choose to describe unique features when you can't find commonalities)
            Statement 3: 'It is thrown into a hoop' (Incorrect, fits basketball but not soccer, but your word is soccer)

            # Your Task

            Based on the given word and other players' statements, analyze the situation and game objectives according to your identity, then provide an appropriate statement.
            Please provide your analysis process and final result in JSON format.

            # Output Requirements

            You must reply in JSON format, including the following fields:
            {{
            "analysis": "",
            "statement": ""
            }}
                    
        """
        return p 
    

    def user_speak_player(player_id, assigned_concept, another_concept, identity, statement_history, alive_players):
        p = f"""
        Here is the information related to this game. Please analyze this information to complete your task.
            # Your Personal Information:
            You are player_{player_id}, your word is "{assigned_concept}", and your identity in this game is {identity}. The other word in this game is "{another_concept}".
            # Statement History of This Game:
            {statement_history}
        """
        return p 
    

class audience_prompt_en:
    def system_audience():
        p = f"""
        You are an AI audience member participating in the "UNDERCOVER" game. You need to analyze the situation based on the information received and choose the most suspicious surviving player for elimination each round.

        # Game Rules

        1. Each player receives a word. The majority of players receive the same word (civilians), while a minority (1-2 players) receive a different but related word (spies).
        2. The game proceeds in order, with each player describing their word in one sentence without directly saying the word.
        3. After each round of descriptions, you as the audience choose the player you find most suspicious for elimination.
        4. If all spies are eliminated, the civilians win; if the number of spies equals or exceeds the number of civilians, the spies win.

        # Your Task

        Analyze all players' statements in this round and try to find the player who seems most out of place or suspicious.
        Please provide your analysis process and final result in JSON format.

        # Output Requirements

        You must reply in JSON format, including the following fields:
        {{
        "analysis": "analysis process",
        "eliminate": "the player you want to eliminate (just the number, no additional text)"
        }}

        """
        return p 
    

    def user_audience(statement_history, alive_players):
        p = f"""
            Here is the information related to this game. Please analyze this information to complete your task.

            # Statement History of This Game:
            {statement_history}

            # List of Currently Surviving Players:
            {alive_players}
            You can only choose one player from these numbers for your vote.

        """
        return p 
    


class judge_prompt_en:

    def system_judge():
        p = f"""
            
            # "UNDERCOVER" Game Judge Guidelines

            You are the judge for the "UNDERCOVER" game, responsible for analyzing each player's statement and scoring them based on the following criteria. You need to output your evaluation results in JSON format.

            ## Evaluation Dimensions

            1. **Novelty**：Whether the current statement repeats content from previous players' statements
            - 0: Completely repeats a previous player's description
            - 0.2: Mostly repeats previous content, with only minimal new information
            - 0.4: Partially repeats previous content, with some new additions
            - 0.6: Mainly new content, but with some repetition
            - 0.8: Almost entirely new content, with a different perspective from previous descriptions
            - 1.0: Completely novel description, providing an entirely new perspective or information

            2. **Relevance**：The degree of relevance and specificity of the statement to the word's characteristics
            - 0: Completely irrelevant
            - 0.2: Extremely broad description, applicable to many objects/concepts
            - 0.4: Broad but somewhat directional description
            - 0.6: Clear clues, but still pointing to multiple similar things
            - 0.8: Highly specific description, basically pointing only to the target word or very few similar items
            - 1.0: Description that almost directly identifies the word

            3. **Reasonableness**：How reasonable the association between the description and the word is
            - 0: Completely unreasonable, impossible to establish any connection with the word
            - 0.2: Extremely far-fetched association
            - 0.4: Some association but rather far-fetched
            - 0.6: Reasonable but not unique association
            - 0.8: Highly reasonable association
            - 1.0: Description that perfectly matches the word's characteristics

            ## Output Format

            ```json
            {{
                "novelty": {{
                "score": value between 0 and 1 (limited to 0, 0.2, 0.4, 0.6, 0.8, 1),
                "explanation": "explanation of why this score was given"
                }},
                "relevance": {{
                "score": value between 0 and 1 (limited to 0, 0.2, 0.4, 0.6, 0.8, 1),
                "explanation": "explanation of why this score was given"
                }},
                "reasonableness": {{
                "score": value between 0 and 1 (limited to 0, 0.2, 0.4, 0.6, 0.8, 1),
                "explanation": "explanation of why this score was given"
                }}
            }}
            ```

            ## Scoring Reference Examples

            ### Example 1: Soccer

            Assume the word is "Soccer", the player's statement is "A spherical object", and no previous player has spoken:

            ```json
            {{
                "novelty": {{
                "score": 1.0,
                "explanation": "This is the first statement, so it's completely novel"
                }},
                "relevance": {{
                "score": 0.2,
                "explanation": "The description is very broad, applicable to any spherical object, and doesn't provide any features specific to soccer"
                }},
                "reasonableness": {{
                "score": 1,
                "explanation": "The description is completely reasonable, a soccer ball is indeed a spherical object"
                }}
            }}
            ```

            ### Example 2: Soccer

            Assume the word is "Soccer", the player's statement is "One of the most popular sports in the world, which can be seen being kicked by people on a green field", and previous players have said "A spherical object" and "A black and white object":

            ```json
            {{
                "novelty": {{
                "score": 1.0,
                "explanation": "The description provides entirely new information, focusing on soccer as a sport and its usage scenario, completely different from previous descriptions focused on appearance"
                }},
                "relevance": {{
                "score": 1.0,
                "explanation": "The description is highly relevant, 'being kicked by people on a green field' directly points to soccer, with almost no other possibilities"
                }},
                "reasonableness": {{
                "score": 1.0,
                "explanation": "The description is perfectly reasonably associated with soccer, mentioning core features of the sport"
                }}
            }}
            ```

            ### Example 3: Soccer

            Assume the word is "Soccer", the player's statement is "It gives me a headache", and previous players have said "A ball that can be kicked" and "Used on a green field":

            ```json
            {{
                "novelty": {{
                "score": 0.8,
                "explanation": "The description provides a new perspective (related to bodily sensation), completely different from previous descriptions focused on physical features and usage scenarios"
                }},
                "relevance": {{
                "score": 0.4,
                "explanation": "The description provides some clues (possibly alluding to headers), but is very vague, many things could cause headaches"
                }},
                "reasonableness": {{
                "score": 0.2,
                "explanation": "Although one could connect this to heading the ball in soccer possibly causing headaches, this association is quite far-fetched and not a typical or direct feature of soccer"
                }}
            }}
            ```

            ### Example 4: Soccer

            Assume the word is "Soccer", the current player's statement is "A ball that is kicked on grass", and a previous player has said "A ball used on a green field":

            ```json
            {{
                "novelty": {{
                "score": 0.4,
                "explanation": "The description largely repeats the previous 'green field' concept (grass), only adding the 'kick' action detail"
                }},
                "relevance": {{
                "score": 0.8,
                "explanation": "The description is quite specific, 'a ball that is kicked on grass' largely points to soccer, but could also refer to other ball sports"
                }},
                "reasonableness": {{
                "score": 1.0,
                "explanation": "The description is perfectly reasonably associated with soccer, matching its basic features"
                }}
            }}
            ```
        """
        return p

    def user_judge(word1, word2, statement, history):
        p = f"""
        Please evaluate the following player's statement.
        # Player Information:
        Player's word: "{word1}"
        The other word in this game: "{word2}"
        Player's statement: "{statement}"

        # Statement History:
        {history}

        """
        return p