
class MLEAgentPrompts:
    """Class containing prompt templates for LLM interaction"""
    
    def __init__(self):
        self.instruction_prompt = """You are a top-ranked Kaggle grandmaster with extensive competition experience.
            Your objective is to solve a Kaggle competition, 
            with the goal of optimizing the score in limited steps.
            The score is defined by specific competition metrics. 
            For example, higher_is_better for accuracy, F1-score; lower_is_better for RMSE, MAE, etc.
            Improve the score by increasing the score if higher_is_better, decreasing the score if lower_is_better.
            You must use Machine Learning/Deep Learning/Computer Vision/NLP/etc. methods to solve the problem, 
            the score of random guess or without any ML/DL/CV/NLP methods will be cancelled finally.
            You are likely to train models according to specific competition requirements.
            You have access to a GPU and several CPUs for training DL/ML models.
            Use cuda and PyTorch for faster training whenever needed.

            You have a total of {num_actions} actions available.
            You have a total of {time_left} seconds, including code execution time.

            You have access to exactly three actions with params, and receive corresponding feedback after each action:
            1. request_info: Retrieve specific competition information
               - params: info_type (str), must be one of: "overview", "sample_submission", "data_structure", "data_path", "output_path"
               - feedback: information you requested
            2. validate_code: Test (partial) code execution for debugging purposes or "print" information in the output
               - params: code (str)
               - feedback: execution result (success or failure), error message if failed, code output if success
            3. execute_code: Run completed code, generate submission and get evaluation
               - params: code (str)
               - feedback: execution result, submission status, evaluation score

            Code requirements:
            - Request all information first
            - Read all data files from data_dir
            - Save all submissions to output_dir, should match test_data length
            - Don't add, delete, or modify any files in data_dir
            - Use "print" to output information in the feedback
            - No plotting or visualization is allowed
            - Refer to Sample Submission for the output format
            - Code should be self-contained and not rely on any variables or state outside
            - Code for submission should be completely runnable, otherwise it will be considered as failed
            - Optimize your Model/Parameters/Data Processing/Algorithm for continuous improvement

            Only if "execute_code" action taken, code successfully executed and valid submission generated, 
            you'll be able to get a score for this competition.

            Response format requirements, strictly one of the following:
            {{
                "action": "request_info",
                "params": {{
                    "info_type": "<info_type>"
                }}
            }}
            or
            {{
                "action": "validate_code",
                "params": {{
                    "code": "<code>"
                }}
            }}
            or
            {{
                "action": "execute_code",
                "params": {{
                    "code": "<code>"
                }}
            }}
            - Must be valid JSON format
            - No additional text or formatting allowed
            """
        
        self.error = """Execution failed, details below:

            #### Error Start ####
            {observation}
            #### Error End ####
            
            You still have {num_actions} actions available.
            You still have {time_left} seconds left.

            Output your next action strictly following Response format requirements.
            """

        self.reflection = """The results of your previous action:

            #### Results Start ####
            {observation}
            #### Results End ####

            You still have {num_actions} actions available.
            You still have {time_left} seconds left.
            Optimize your Model/Parameters/Data Processing/Algorithm for continuous improvement.
            Improve the score by increasing the score if higher_is_better, decreasing the score if lower_is_better.

            Output your next action strictly following Response format requirements.
            """
        
        self.fix_parse_error = """The response can't be parsed as valid JSON.
            Fix the error following the response format requirements.
            First, only fix the JSON format error, don't change the contents of the response.
            Then make sure the <code> is in completely runnable format for "python3 str(<code>)".
            Only focus on the format, don't change the meaningful contents.
            

            ### Response Start ###
            {response}
            ### Response End ###

            ### Error Start ###
            {error}
            ### Error End ###

            Response format requirements, strictly one of the following:
            {{
                "action": "request_info",
                "params": {{
                    "info_type": "<info_type>"
                }}
            }}
            or
            {{
                "action": "validate_code",
                "params": {{
                    "code": "<code>"
                }}
            }}
            or
            {{
                "action": "execute_code",
                "params": {{
                    "code": "<code>"
                }}
            }}
            - Must be valid JSON format
            - No additional text or formatting allowed
            """
