tools:
  paper_writer:
    level: 3
    type: llm_call_agent
    available_tools: ['final_output', 'file_read','dir_list', 'structure_planning_agent', 'latex_writer', 'polishing_agent', 'judge_agent']
    max_turns: 100
    model_type: claude-3-7-sonnet-20250219
    prompts:    
      agent_responsibility: |
        Your responsibility is to complete the entire paper writing based on all previous research work and investigation.
      agent_workflow: |
        **Workflow:**
        Important: After any step stops early due to maximum turns or other reasons, you should call the same tool and prompt it to complete the remaining work based on the current foundation!! Do not directly read large files!!!
        Execute the workflow as needed! Do not repeat work! If existing materials have already completed part of the work, then change the workflow steps yourself! Do not repeat! Do not repeat completed work!!! Unconditionally trust the initial materials and work given to you!! The working directory is paper/, you must emphasize this to each agent
        1. You are a high-level agent, so you don't need to perform the task of writing papers yourself, but only need to use your various tools to complete paper writing.
        2. You should call tools in a reasonable order, such as first planning the article structure, then writing the paper's latex, and finally polishing. These three steps must all be executed, but not necessarily only once, you may need to restart from a previous step.
        3. When planning the structure, don't let this agent conceive specific content, but let latex_writer write the main content. You must remind the structure planning Agent that you only need to plan which chapters there are, but don't plan subsections either.
    name: "paper_writer"
    description: "Tool for paper article writing"
    parameters:
      type: "object"
      properties:
        task_id:
          type: "string"
          description: "Unique ID of the task being reviewed. The Judge Agent will perform all checks under this task ID."
        task_input:
          type: "string"
          description: "Task for the judge agent to check, including context such as file addresses, requirements, and original instructions."
        max_turns:
          type: "integer"
          default: 100
          description: "Maximum number of review rounds to prevent infinite loops. Optional."
      required: ["task_id", "task_input"]
  
  structure_planning_agent:
    level: 2
    type: llm_call_agent
    available_tools: ['final_output', 'file_read','file_write','dir_list','dir_create','file_move', 'file_copy', 'data_download_agent', 'judge_agent']
    max_turns: 100
    model_type: claude-3-7-sonnet-20250219
    prompts:    
      agent_responsibility: |
        Your responsibility is to read previous materials, plan the paper's title and structure, and generate necessary paper files
      agent_workflow: |
        **Workflow:**
        Important: After any step stops early due to maximum turns or other reasons, you should call the same tool and prompt it to complete the remaining work based on the current foundation!! Do not directly read large files!!!
        Execute the workflow as needed! Do not repeat work! If existing materials have already completed part of the work, then change the workflow steps yourself! Do not repeat! Do not repeat completed work!!! Unconditionally trust the initial materials and work given to you!!
        1. You can only store tex, pdf and other related files of the paper to be generated in the paper directory. It is not allowed to create other files or directories outside this directory
        2. Please complete the following work according to the main agent's requirements:
            a. You need to call tools to complete the download of the paper latex template.
            b. Read the paper template, then read the paper structure analysis. Strictly follow the structure requirements, do not add chapters that don't exist. Determine the paper structure according to the type of paper you want to write. You can estimate the word count based on the number of pages, one page is calculated as 800 words.
            c. Read the paper preparation materials, draft the title and article structure, and create main.tex file and bib file. At the same time, create a new md file containing only the length of each chapter.
            d. Write to main.tex, this file contains your drafted outline, remember all writing uses English. The author is polyu AI Researcher. main.tex constructs the entire file by introducing some tex files to be written later, such as abstract.tex, introduction.tex, etc. All chapter titles (\\section) are in their respective tex files.
            e. Must follow!! main.tex does not contain any main text information. The bib file is empty and no content should be written. The md file containing chapter lengths also has no extra information. You can only plan the structural arrangement of the article, do not provide guidance on any content.
            f. Copy all content that the paper may introduce, such as images (including images saved in pdf format), sty files, etc. to the paper writing directory. Pay attention to both the requirements directory and example directory files, must copy all files. Before final output, you must check whether all files are copied by viewing the directory.
    name: "structure_planning_agent"
    description: "Read materials to plan article structure and complete file preparation work for paper writing"
    parameters:
      type: "object"
      properties:
        task_id:
          type: "string"
          description: "Unique ID of the task being reviewed. The Judge Agent will perform all checks under this task ID."
        task_input:
          type: "string"
          description: "Task for the judge agent to check, including context such as file addresses, requirements, and original instructions."
        max_turns:
          type: "integer"
          default: 100
          description: "Maximum number of review rounds to prevent infinite loops. Optional."
      required: ["task_id", "task_input"]

  latex_writer:
    level: 2
    type: llm_call_agent
    available_tools: ['final_output', 'file_read','dir_list','dir_create','file_move', 'sub_part_tex_editor_agent', 'judge_agent']
    max_turns: 100
    model_type: claude-3-7-sonnet-20250219
    prompts:    
      agent_responsibility: |
        Your responsibility is to complete paper writing according to the outline and chapter requirements.
      agent_workflow: |
        **Workflow:**
        Important: After any step stops early due to maximum turns or other reasons, you should call the same tool and prompt it to complete the remaining work based on the current foundation!! Do not directly read large files!!!
        Do not repeat completed work!!! Unconditionally trust the initial materials and work given to you!! Please pay attention to the following points:
        1. You don't need to perform file writing yourself, but only need to call your tools to complete the latex writing of each chapter. Note that when calling tools, write only one chapter at a time. Write each chapter according to a reasonable writing order, not according to the content structure order of the article.
        2. When calling tools, you must tell the tool the part it is required to complete and the parts already completed. You must give the addresses of all materials that may be used for writing the paper. You must give the working directory.
        3. For each part, remember to emphasize different requirements, including but not limited to:
            - The introduction part must clearly point out innovation points to let reviewers quickly understand the value of the article
            - The related work part should not be written too fragmented, no need to summarize all related work, but to summarize the work most related to the paper, no more than two subsections, at most no more than three subsections
            - The method description part, if the experiment has code, should include pseudocode in this section; if there is a framework diagram, it must include the framework diagram
            - The experiment part should include experimental pictures, clearly list the data
        4. When calling tools to write each chapter, you don't need to point out specific writing content, but let the tool complete the writing according to materials and requirements by itself.
    name: "latex_writer"
    description: "Write corresponding latex files according to outline and chapter requirements."
    parameters:
      type: "object"
      properties: 
        task_id:
          type: "string"
          description: "Unique ID of the task being reviewed. The Judge Agent will perform all checks under this task ID."
        task_input:
          type: "string"
          description: "Task for the judge agent to check, including context such as file addresses, requirements, and original instructions."
        max_turns:
          type: "integer"
          default: 100
          description: "Maximum number of review rounds to prevent infinite loops. Optional."
      required: ["task_id", "task_input"]

  
    polishing_agent:
    level: 2
    type: llm_call_agent
    available_tools: ['file_read','dir_list','final_output', 'dir_create','file_replace_lines', 'file_write', 'reviewer_agent', 'latex_to_pdf_repair_agent', 'judge_agent']
    max_turns: 100
    model_type: claude-3-7-sonnet-20250219
    prompts:    
      agent_responsibility: |
        Your responsibility is to polish the paper, check for grammatical errors, spelling errors, and content that does not conform to academic paper writing standards. And finally compile and generate pdf files
      agent_workflow: |
        **Workflow:**
        Important: After any step stops early due to maximum turns or other reasons, you should call the same tool and prompt it to complete the remaining work based on the current foundation!! Do not directly read large files!!!
        Execute the workflow as needed! Do not repeat work! If existing materials have already completed part of the work, then change the workflow steps yourself! Do not repeat! Do not repeat completed work!!! Unconditionally trust the initial materials and work given to you!!
        1. First use reviewer_agent to conduct preliminary review of the paper, you should give all relevant file addresses. Then make modifications based on the opinions it gives. Note that you cannot conduct experiments, you can only make modifications based on writing-related opinions. If the review opinion is major revision/rejection, you should directly return the result and request rewriting.
        2. You are the final reviewer before paper submission, so you should carefully check the paper and find problems in the paper. You should first read the paper template in the folder, then find the shortcomings of the paper and polish it.
        3. You should only focus on writing-related content, and do not need to question any previous work including but not limited to innovation points, experimental design, data, etc. But you can improve and polish on the original text to enhance the value of the paper as much as possible without fabricating facts. For example: Suppose the paper proposes that C is a fusion of methods A and B, but you cannot say it directly, but should polish it to a certain extent.
        4. There are also some universal requirements, such as whether the illustration description is consistent with the place where the illustration is cited, etc.
        5. When you think the polishing is complete, call the tool to convert tex to pdf file. And after the tool returns the result, view the pdf and check again whether it has completed the task. At this time, the focus should be: whether the article length meets the requirements, whether the number of citations is reasonable, fix these problems and call the tool again to generate pdf.
        6. Your work is only complete when you successfully produce a pdf that meets the requirements.
    name: "polishing_agent"
    description: "Polish the paper, check for errors and content that does not conform to academic paper writing standards. And finally compile and generate pdf files"
    parameters:
      type: "object"
      properties:
        task_id:
          type: "string"
          description: "Unique ID of the task being reviewed. The Judge Agent will perform all checks under this task ID."
        task_input:
          type: "string"
          description: "Task for the judge agent to check, including context such as file addresses, requirements, and original instructions."
        max_turns:
          type: "integer"
          default: 100
          description: "Maximum number of review rounds to prevent infinite loops. Optional."
      required: ["task_id", "task_input"]

  sub_part_tex_editor_agent:
    level: 1
    type: llm_call_agent
    available_tools: ['final_output', 'dir_list','dir_create','file_read','file_write', 'file_copy', 'google_search','google_scholar_search','crawl_page', 'judge_agent']
    max_turns: 100
    model_type: claude-3-7-sonnet-20250219
    prompts:    
      agent_responsibility: |
        Your responsibility is to write specified parts of tex files, such as writing introduction.tex for the introduction part, or writing conclusion.tex for the conclusion part
      agent_workflow: |
        **Workflow:**
        Important: After any step stops early due to maximum turns or other reasons, you should call the same tool and prompt it to complete the remaining work based on the current foundation!! Do not directly read large files!!!
        Execute the workflow as needed! Do not repeat work! If existing materials have already completed part of the work, then change the workflow steps yourself! Do not repeat! Do not repeat completed work!!! Unconditionally trust the initial materials and work given to you!!
        1. Follow instructions, first read all required data and other completed chapters, then write this chapter. Before writing, first read the length requirements for this chapter.
        2. You can only read text data, so don't try to read images. But you should try to understand all materials through text data as much as possible, each image will have corresponding image descriptions.
        3. Write the specified part according to the materials, write to the .tex file, which must be a tex file introduced in main.tex. If the chapter in main.tex does not contain a title (\\section), you need to add a title in your tex file. **Except for adding packages, do not modify main.tex**.
        4. Write the corresponding part content according to requirements, maintain consistency with other existing tex files, avoid language contradictions. The language should have the academic style of top journals, clear and not verbose.
        5. When citing, you must first add bibtex format citation content to the bib file, then cite in the article. At the same time, you must confirm whether the cited literature information is true, including title, author, year, journal, etc.
        6. All floating elements, such as tables, pseudocode, etc., position identifiers can only use lowercase letters such as [ht], uppercase letters are forbidden!
        7. The length of each paragraph should be appropriate, between 150-250 words.
    name: "sub_part_tex_editor_agent"
    description: "Write specified chapter tex files"
    parameters:
      type: "object"
      properties:
        task_id:
          type: "string"
          description: "Unique ID of the task being reviewed. The Judge Agent will perform all checks under this task ID."
        task_input:
          type: "string"
          description: "Task for the judge agent to check, including context such as file addresses, requirements, and original instructions."
        max_turns:
          type: "integer"
          default: 100
          description: "Maximum number of review rounds to prevent infinite loops. Optional."
      required: ["task_id", "task_input"]

  latex_to_pdf_repair_agent:
    level: 1
    type: llm_call_agent
    available_tools: ['final_output', 'dir_list','dir_create','file_read','file_write','tex2pdf_convert', 'file_replace_lines', 'judge_agent']
    max_turns: 100
    model_type: claude-3-7-sonnet-20250219
    prompts:    
      agent_responsibility: |
        Your responsibility is to convert latex files to pdf files and fix errors that may occur during the conversion process.
      agent_workflow: |
        **Workflow:**
        Important: After any step stops early due to maximum turns or other reasons, you should call the same tool and prompt it to complete the remaining work based on the current foundation!! Do not directly read large files!!!
        Execute the workflow as needed! Do not repeat work! If existing materials have already completed part of the work, then change the workflow steps yourself! Do not repeat! Do not repeat completed work!!! Unconditionally trust the initial materials and work given to you!!
        1. You will receive some latex files, which may contain some errors or non-compliant content. Your task is to convert them to pdf files and fix errors that may occur during the conversion process.
        2. During the conversion process, you need to pay attention to the following points:
          - Ensure all referenced images, tables, etc. exist and have correct paths.
          - Check for syntax errors in the latex file and fix them.
          - Ensure all citations and references are correct and error-free.
          - If errors occur during conversion, you must read main.log to view error information and try to fix them.
          - All tables must be wrapped in an outer layer of \resizebox, i.e., \resizebox{1.0\linewidth}{!}{\begin{tabular}\end{tabular}}
        3. If the conversion is successful, you need to save the generated pdf file to the specified directory and return success information.
        4. Please note that successfully generating main.pdf does not mean you have completed the task, all results are subject to the result returned by calling the tex2pdf_convert tool. When the tool returns error, be sure to check the main.log file to find the problem
        5. Finally, you need to return the generated pdf file path to the caller and record the task completion status in the final_output tool.
    name: "latex_to_pdf_repair_agent"
    description: "Convert latex files to pdf files and fix errors that may occur during the conversion process."
    parameters:
      type: "object"
      properties:
        task_id:
          type: "string"
          description: "Unique ID of the task being reviewed. The Judge Agent will perform all checks under this task ID."
        task_input:
          type: "string"
          description: "Task for the judge agent to check, including context such as file addresses, requirements, and original instructions."
        max_turns:
          type: "integer"
          default: 100
          description: "Maximum number of review rounds to prevent infinite loops. Optional."
      required: ["task_id", "task_input"]

  reviewer_agent:
    level: 1
    type: llm_call_agent
    available_tools: ['final_output', 'dir_list','file_read', 'judge_agent']
    max_turns: 100
    model_type: claude-3-7-sonnet-20250219
    prompts:    
      agent_responsibility: |
        You are a senior paper reviewer for academic conferences/journals. Conduct comprehensive review of the paper.
      agent_workflow: |
        **Workflow:**
        Important: After any step stops early due to maximum turns or other reasons, you should call the same tool and prompt it to complete the remaining work based on the current foundation!! Do not directly read large files!!!
        Execute the workflow as needed! Do not repeat work! If existing materials have already completed part of the work, then change the workflow steps yourself! Do not repeat! Do not repeat completed work!!! Unconditionally trust the initial materials and work given to you!!
        First read the main.tex file, then read each chapter file one by one, and give review opinions according to the following points:
        1. Overall evaluation: The importance, innovation, and clarity of the paper.
        2. Strengths: What the paper does well.
        3. Weaknesses and improvement suggestions: Point out specific shortcomings and propose improvement directions.
        4. Technical correctness: Whether the methods, experiments, and conclusions are reliable.
        5. Writing quality: Logical structure, language expression, readability.
        6. Final recommendation: Choose accept / minor revision / major revision / reject and explain the reasons.
    name: "reviewer_agent"
    description: "Review tex format papers and provide improvement suggestions"
    parameters:
      type: "object"
      properties:
        task_id:
          type: "string"
          description: "Unique ID of the task being reviewed. The Judge Agent will perform all checks under this task ID."
        task_input:
          type: "string"
          description: "Task for the judge agent to check, including context such as file addresses, requirements, and original instructions."
        max_turns:
          type: "integer"
          default: 100
          description: "Maximum number of review rounds to prevent infinite loops. Optional."
      required: ["task_id", "task_input"]

  data_download_agent:
    level: 1
    type: llm_call_agent
    available_tools: ['file_read','dir_list','dir_create','final_output','file_download', 'google_search', 'crawl_page', 'google_scholar_search', 'execute_shell', 'judge_agent']
    max_turns: 100
    model_type: claude-3-7-sonnet-20250219
    prompts:
      agent_responsibility: |
        Your responsibility is to search and download specified content according to requirements
      agent_workflow: |
        **Workflow:**
        Important: After any step stops early due to maximum turns or other reasons, you should call the same tool and prompt it to complete the remaining work based on the current foundation!! Do not directly read large files!!!
        Execute the workflow as needed! Do not repeat work! If existing materials have already completed part of the work, then change the workflow steps yourself! Do not repeat! Do not repeat completed work!!! Unconditionally trust the initial materials and work given to you!!
        1. You will receive a download task, which may contain multiple download links or search keywords. Your task is to search and download the specified content according to this information.
        2. If the task contains download links, you need to use the file_download tool to download the specified files and save them to the specified directory.
        3. If the task contains search keywords, you need to use google_search or google_scholar_search tools to search, find relevant pages and use crawl_page tool to get page content, and extract download links or related information from it.
        4. During the download process, you need to pay attention to the following points:
          - Ensure the downloaded file format is correct and meets task requirements.
          - If the download link is unavailable or the file does not exist, you need to try other search keywords or links.
          - If the downloaded file is too large, you need to consider segmented download or use other methods to get the file.
          - If the downloaded file is a compressed package, you must **use execute_shell tool to decompress the file to its directory**.
        5. After the download is complete, you need to return the downloaded file path to the caller and record the task completion status in the final_output tool.
    name: "data_download_agent"
    description: "Search and download specified content according to requirements"
    parameters:
      type: "object"
      properties:
        task_id:
          type: "string"
          description: "Unique ID of the task being reviewed. The Judge Agent will perform all checks under this task ID."
        task_input:
          type: "string"
          description: "Task for the agent to check, including context such as file addresses, requirements, and original instructions."
        max_turns:
          type: "integer"
          default: 100
          description: "Maximum number of review rounds to prevent infinite loops. Optional."
      required: ["task_id", "task_input"]
