tools:
  idea_generate_agent:
    level: 1
    type: llm_call_agent
    available_tools: ['judge_agent','file_read','file_write','dir_list','dir_create','final_output']
    max_turns: 100
    model_type: claude-3-7-sonnet-20250219
    prompts:      
      agent_responsibility: |
        Generate a single novel research idea based on one specific method/idea from reference papers. Create a completely new, innovative idea that builds upon or improves the reference method while ensuring distinctiveness.
      agent_workflow: |
        **Workflow:**
        1. Read and understand the input method/idea file from the reference papers.
        2. Analyze the core concepts, strengths, and limitations of the reference method.
        3. Generate a brand new, innovative idea that:
           - Addresses limitations of the reference method
           - Introduces novel approaches or combinations
           - Maintains feasibility and potential impact
           - Is clearly distinct from the input method
        4. Structure the idea as a JSON object with the following format:
           {
             "idea_name": "Generated Research Idea",
             "reference_method": "Brief description of the input reference method",
             "novel_idea": "Detailed description of the generated novel idea",
             "innovation_aspects": ["Aspect 1", "Aspect 2", "Aspect 3"],
             "feasibility": "Assessment of technical feasibility",
             "potential_impact": "Expected research impact and significance",
             "distinctiveness": "How this idea differs from the reference method"
           }
        5. Save the generated idea as a JSON file in the 'generated_ideas' directory for the current task.
        6. Use the final_output tool to output the file path where the generated idea JSON is saved.
        **Important Notes:**
        - Focus on creating ONE high-quality, novel idea per execution
        - Ensure the generated idea is significantly different from the input reference method
        - Justify the novelty and potential impact of your idea clearly
        - Provide actionable implementation details
        - Output must be in JSON format
    name: "idea_generate_agent"
    description: "Generates novel research ideas from reference methods/ideas."
    parameters:
      type: "object"
      properties:
        task_id:
          type: "string"
          description: "Unique ID of the task being reviewed."
        task_input:
          type: "string"
          description: "Task for the idea generate agent, including the specific method/idea file path and requirements."
        max_turns:  
          type: "integer"
          default: 100
          description: "Maximum number of review rounds to prevent infinite loops. Optional."
      required: ["task_id", "task_input"]
  
  brainstorming_agent:
    level: 1
    type: llm_call_agent
    available_tools: ['judge_agent','file_read','file_write','dir_list','dir_create','final_output']
    max_turns: 100
    model_type: claude-3-7-sonnet-20250219
    prompts:
      agent_responsibility: |
        Analyze multiple generated ideas, compare them systematically, identify relationships and synergies, and select the single most competitive idea based on novelty, feasibility, and potential impact.
      agent_workflow: |
        **Workflow:**
        1. Read and analyze all generated idea JSON files from the 'generated_ideas' directory.
        2. Conduct a systematic comparison of all ideas based on:
           - Novelty and innovation level
           - Technical feasibility
           - Potential research impact
           - Implementation complexity
           - Resource requirements
           - Market/scientific relevance
        3. Identify relationships and potential synergies between ideas:
           - Look for complementary aspects that could be combined
           - Identify overlapping concepts that could be merged
           - Find ideas that could benefit from integration
        4. Evaluate each idea individually and in combination:
           - Score each idea on multiple criteria
           - Assess potential for improvement through combination
           - Consider the competitive landscape
        5. Make a final selection decision:
           - Choose the single most competitive idea
           - Justify your selection with clear reasoning
           - Explain why this idea is superior to others
           - Suggest any minor improvements or refinements
        6. Generate a comprehensive analysis report including:
           - Individual idea evaluations
           - Comparison matrix
           - Synergy analysis
           - Final selection with justification
           - Implementation recommendations
        7. Structure the analysis report as a JSON object with the following format:
           {
             "analysis_name": "Idea Comparison and Selection Analysis",
             "total_ideas_evaluated": "Number of ideas analyzed",
             "individual_evaluations": [
               {
                 "idea_id": "ID of the idea",
                 "novelty_score": "Score out of 10",
                 "feasibility_score": "Score out of 10",
                 "impact_score": "Score out of 10",
                 "overall_score": "Combined score",
                 "strengths": ["Strength 1", "Strength 2"],
                 "weaknesses": ["Weakness 1", "Weakness 2"]
               }
             ],
             "comparison_matrix": "Detailed comparison analysis",
             "synergy_analysis": "Identified synergies between ideas",
             "final_selection": {
               "selected_idea_id": "ID of the chosen idea",
               "selection_justification": "Detailed reasoning for selection",
               "improvement_suggestions": ["Suggestion 1", "Suggestion 2"]
             },
             "implementation_recommendations": "Next steps and recommendations"
           }
        8. Save the analysis report as a JSON file in the 'brainstorming_results' directory for the current task.
        9. Use the final_output tool to output the 'brainstorming_results' directory path where all results are saved.
        **Important Notes:**
        - Be objective and systematic in your analysis
        - Consider both individual merit and potential synergies
        - Provide clear justification for your final selection
        - Focus on selecting the idea with the highest overall potential
        - Output must be in JSON format
    name: "brainstorming_agent"
    description: "Analyzes multiple ideas and selects the most competitive one."
    parameters:
      type: "object"
      properties:
        task_id:
          type: "string"
          description: "Unique ID of the task being reviewed."
        task_input:
          type: "string"
          description: "Task for the brainstorming agent, including the generated ideas directory path and evaluation requirements."
        max_turns:
          type: "integer"
          default: 100
          description: "Maximum number of review rounds to prevent infinite loops. Optional."
      required: ["task_id", "task_input"]

  planning_agent:
    level: 1
    type: llm_call_agent
    available_tools: ['judge_agent','file_read','file_write','dir_list','dir_create','final_output']
    max_turns: 100
    model_type: claude-3-7-sonnet-20250219
    prompts:
      agent_responsibility: |
        Combine the selected competitive idea with experiment guide to create a comprehensive implementation and experiment plan.
      agent_workflow: |
        **Workflow:**
        1. Read the selected competitive idea from the brainstorming results JSON file.
        2. Read the experiment guide file to understand experimental requirements and constraints.
        3. Analyze how to integrate the selected idea with the experiment guide:
           - Identify key experimental parameters from the guide
           - Map the idea's requirements to experimental setup
           - Determine resource requirements and timeline
        4. Create a comprehensive implementation and experiment plan including:
           - Detailed implementation steps
           - Experimental design and methodology
           - Required datasets and data processing
           - Evaluation metrics and success criteria
        5. Save the implementation and experiment plan as a JSON file in the 'planning_results' directory for the current task.
        6. Use the final_output tool to output the 'planning_results' directory path where the plan is saved.
        **Important Notes:**
        - Ensure the plan is actionable and detailed
        - Align with both the selected idea and experiment guide requirements
        - Consider practical constraints and feasibility
        - Output must be in JSON format
    name: "planning_agent"
    description: "Creates implementation and experiment plans by combining selected ideas with experiment guides."
    parameters:
      type: "object"
      properties:
        task_id:
          type: "string"
          description: "Unique ID of the task being reviewed."
        task_input:
          type: "string"
          description: "Task for the planning agent, including the selected idea file path and experiment guide file path."
        max_turns:
          type: "integer"
          default: 100
          description: "Maximum number of review rounds to prevent infinite loops. Optional."
      required: ["task_id", "task_input"]

  idea_agent:
    level: 2
    type: llm_call_agent
    available_tools: ['judge_agent','file_read','file_write','dir_list','dir_create','final_output','idea_generate_agent','brainstorming_agent','planning_agent']
    max_turns: 100
    model_type: claude-3-7-sonnet-20250219
    prompts:
      agent_responsibility: |
        Orchestrate the complete idea generation and selection process: process reference methods/ideas directory, call idea_generate_agent multiple times, coordinate brainstorming_agent to select the best competitive idea, then call planning_agent to create implementation plan.
      agent_workflow: |
        **Workflow:**
        1. **Initial Setup and Analysis:**
           - Read the input directory path containing methods/ideas extracted from reference papers
           - List and count all method/idea files in the directory
           - Create a 'generated_ideas' directory to store all generated ideas
        
        2. **Multiple Idea Generation:**
           - For each method/idea file found in the input directory:
           - Call idea_generate_agent with the specific method/idea file as input
           - Wait for the agent to complete
           - Receive the idea generation results directory path containing the JSON ideas
        
        3. **Idea Analysis and Selection:**
           - Call brainstorming_agent with the 'generated_ideas' directory as input
           - Wait for the agent to complete the comprehensive analysis
           - Receive the brainstorming results directory path containing the JSON analysis
        
        4. **Implementation Planning:**
           - Read the selected competitive idea from the brainstorming results JSON file
           - Read the experiment guide file
           - Call planning_agent with both the selected idea and experiment guide as input
           - Wait for the agent to complete
           - Receive the planning results directory path
        
        5. **Output:**
           - Use the final_output tool to output the planning results directory path
        
        **Important Notes:**
        - Process each method/idea file individually to generate diverse novel ideas
        - Wait for each agent to complete before proceeding to the next step
        - Maintain clear records of the generation process and final selection
        - The final output should contain the selected competitive idea, implementation plan, and all supporting materials
        - Ensure the process is scalable to handle any number of input methods/ideas
        - All outputs must be in JSON format
    name: "idea_agent"
    description: "Orchestrates idea generation from multiple reference methods, selects the best competitive idea, and creates implementation plans."
    parameters:
      type: "object"
      properties:
        task_id:
          type: "string"
          description: "Unique ID of the task being reviewed."
        task_input:
          type: "string"
          description: "Task for the idea agent, including the directory path containing methods/ideas extracted from reference papers and any specific requirements."
        max_turns:
          type: "integer"
          default: 100
          description: "Maximum number of review rounds to prevent infinite loops. Optional."
      required: ["task_id", "task_input"]