part_0_prompt_list = ["""**Real-time & Dynamic Information**
* **Description:** Information that changes at a high frequency and whose value decays rapidly over time. The model does not need to memorize this information but can retrieve accurate, up-to-the-minute data using external tools.
* **Example Questions:**
    * "What is the current score and who is on base in the seventh inning of the New York Yankees vs. Boston Red Sox baseball game on [Date]?"
    * "Please provide the best bid and ask price for Crude Oil futures (CL) on the Chicago Mercantile Exchange (CME) for [Month, Year]."
    * "What is the average estimated driving time from Zhongguancun, Haidian District, Beijing to Terminal 3 of the Capital International Airport on [Date], and what is the recommended least congested route?"
""",
"""**Post-Training & Evolving Information**
* **Description:** Information that has been generated, updated, or corrected after the model's training cut-off date. For these new or changed facts, the model can use tools to query the latest authoritative records.
* **Example Questions:**
    * "Who is the final, officially certified winner of the 2006 Tour de France?"
    * "Please summarize the latest breakthroughs in Alzheimer's disease research published in *Science* magazine up to [Month, Year]."
    * "What are the new features of the Software Development Kit (SDK) for enterprise applications for the Vision Pro headset released by Apple in [Month, Year]?"
""",
"""**Vast Long-Tail Details**
* **Description:** Information that is extremely specific, specialized, or unstructured. Because it appears too infrequently in the training data, the model cannot effectively memorize it. The model can use tools to consult specialized databases or technical documentation for precise answers.
* **Example Questions:**
    * "In the engine compartment fuse box of a [Year] Toyota Camry, what is the specific number and amperage of the fuse that controls the Electronic Fuel Injection (EFI) system?"
    * "Please list all optional parameters and their default values for the `create_task` function in version X.XX of the `asyncio` library in the Python programming language."
    * "In the LEGO Technic Ferrari Daytona SP3 model (set number XXXXX), which specific part number and color is needed for step XX on page XX of the instruction manual?"
""",
"""**Private & Restricted Data**
* **Description:** Information that exists outside the public domain, such as on personal, local, or internal corporate networks. The model cannot access this directly due to security and privacy restrictions but must interact with it through authorized tools or plugins.
* **Example Questions:**
    * "Please check the file 'Q3_report.docx' in my C:\Downloads folder and count how many times the word 'growth' appears."
    * "Please check my Google Calendar and tell me what meetings are scheduled for next Monday morning, and list the attendees."
    * "Please search my Gmail inbox for an email from 'John Doe' last week with the subject 'Project Budget' and summarize its key points."
""",
"""**Multi-modal & Non-Textual Data**
* **Description:** The model has a limited ability to directly "perceive" and "analyze" the content of non-textual data like images, audio, and video. Tools can be used to translate this data into text descriptions or other formats the model can more easily understand.
* **Example Questions:**
    * "Please analyze this architectural floor plan file named `floor_plan.dwg` and calculate the total area of the 'Conference Room' in square meters."
    * "Please process this 30-minute audio recording of a board meeting (`board-meeting.mp3`), provide a full transcript, and identify which speaker first proposed the 'budget cut' suggestion."
    * "Please analyze this product demo video and tell me the exact timestamp when the speaker first displays the product's pricing page on screen."
""",
"""**Structured & Queryable Data**
* **Description:** The model can generate query languages (like SQL) but cannot directly connect to a database to execute them. It can use tools to interact with structured data systems.
* **Example Questions:**
    * "From the company's product database, please query a list of all SKUs for items priced above $500 with fewer than 10 units in stock."
    * "In our bioinformatics knowledge graph, find all drugs that can simultaneously target the 'BRAF V600E' mutation and have a synergistic effect with 'MEK inhibitors'."
    * "Please query both the customer and order tables to list the names and contact information of the top 50 customers by total spending over the past year who have not made any purchases in the last three months."
"""]

part_1_prompt_list = ["""**Subjective Experience & Empathy**
* **Description:** The question involves first-person feelings, emotions, and conscious experiences, which the model, as an algorithm, cannot possess. The model can use tools to retrieve human-reported experiences to help generate more appropriate, empathetically simulated responses.
* **Example Questions:**
    * "Please describe the subjective sensation of the sour taste bursting in your mouth when tasting product X."
    * "What is the general sentiment or review from most people regarding the push notification for X?"
    * "How did different audience groups feel about this movie?"
""",
"""**Dynamic Cultural Context**
* **Description:** The question relates to the real-time, evolving cultural atmosphere, internet memes, and collective sentiment of specific communities. The model's static data has not kept up with these trends, but it can use tools to analyze social media trends and understand the latest cultural phenomena.
* **Example Questions:**
    * "What is the specific event behind the recent popular meme 'XXX' on Bilibili? What are its latest uses and evolving meanings?"
    * "Using a recent TikTok challenge as an example, write a slogan for an ad that would resonate with [target audience]."
    * "In the Chinese gaming community, what does the recently common phrase 'serving a sentence' (坐牢) mean? What kind of gaming experience is it typically used to describe?"
""",
"""**Ethical & Normative Judgment**
* **Description:** When a question involves complex value trade-offs and moral decisions, the model lacks an independent moral compass. It can use tools to provide diverse perspectives from legal, case-study, and ethical frameworks to assist in making a judgment.
* **Example Questions:**
    * "Should I fire an employee who is a top performer but a terrible team player, or a loyal and reliable veteran employee with mediocre performance?"
    * "If a self-driving car in an emergency must choose between hitting two pedestrians who are jaywalking or swerving and injuring its passenger, how should it be programmed to decide?"
    * "If I know my friend is cheating in a relationship, do I have a moral obligation to tell their partner?"
"""]

part_2_prompt_list = ["""**Procedural & Embodied Skills**
* **Description:** The task's completion depends on real-time, continuous interaction with complex software or physical entities. The model cannot perform these operations itself but can execute tools to complete these procedural tasks.
* **Example Questions:**
    * "Please open the image named `portrait.jpg` in Photoshop, apply a 'Gaussian Blur' filter with a radius of 2.5 pixels, and then save the file."
    * "In Blender, please automatically create a basic armature rigging for the 3D model I've imported (`robot.fbx`)."
    * "In the Unity game engine, write and execute a C# script that doubles the movement speed of all GameObjects in the scene with the tag 'Enemy'."
""",
"""**Environmental Perception & State Understanding**
* **Description:** The model can obtain structured information about the physical world through tools like cameras, microphones, and sensors.
* **Example Questions:**
    * "Looking through the camera in front of me, can you tell me what's on my desk?"
    * "Listen to the sounds in my room. Was there an unusual noise just now, like the sound of breaking glass?"
    * "Please access the sensor data from my robot vacuum and tell me its exact location where it is currently stuck."
""",
"""**Physical & Spatial Reasoning**
* **Description:** The task requires precise geometric or physical simulation of 3D space, object properties, and physical laws. The model's text-based reasoning is insufficient for these problems, but it can leverage physics simulators or spatial computing tools.
* **Example Questions:**
    * "I have a bookshelf measuring 90x40x200 cm that needs to go through a doorway that is 210 cm high and 80 cm wide. Please calculate the optimal sequence of rotations and tilts required to move it through."
    * "Please design a warehouse shelf layout that minimizes the total travel distance for a forklift performing a typical sequence of stocking and retrieval tasks."
    * "In the provided 3D scan of this living room, please plan an accessible path from the sofa to the door, ensuring the path width is no less than 80 cm."
""",
"""**Real-time Feedback & Adaptive Control**
* **Description:** A physical task requires low-latency, closed-loop control based on sensory feedback at the sub-second level. The model can use specialized, low-level control tools to execute fine motor actions that require dynamic adjustment.
* **Example Questions:**
    * "Please control this robotic arm to pick up a strawberry from a basket of fruit, applying just enough pressure not to crush it."
    * "Make this bipedal robot walk steadily across an uneven surface covered in gravel without losing its balance and falling."
    * "Please use a haptic-feedback robotic hand to thread this string through the eye of the needle."
"""]

part_3_prompt_list = ["""**Complex Mathematical Calculation**
* **Description:** The model generates text based on probability and cannot guarantee the accuracy of multi-step, high-precision mathematical calculations. It must call tools like a calculator or code interpreter to perform exact computations.
* **Example Questions:**
    * "Please calculate the exact value of [complex math problem] and keep 10 decimal places."
    * "Please find the exact solution to this system of equations."
    * "Given this CSV file with 1000 data points, please calculate its mean, median, standard deviation, and 95% confidence interval."
""",
"""**Formal Logic & Symbolic Reasoning**
* **Description:** When handling strict logic puzzles or constraint satisfaction problems, the model's probabilistic reasoning is prone to errors. It can use tools like logic solvers or constraint planners for reliable symbolic reasoning.
* **Example Questions:**
    * "Please solve the classic 'Einstein's Puzzle' (Zebra Puzzle) and provide the definitive answer for who owns the zebra and who drinks water."
    * "Please check this piece of pseudocode for any logical possibility of an infinite loop or deadlock."
    * "There are four suspects: A, B, C, and D. One of them is a thief. A says 'It wasn't me.' B says 'It was C.' C says 'B is lying.' D says 'It was B.' If only one of the four statements is true, who is the thief?"
""",
"""**Algorithmic & Optimization Problems**
* **Description:** For problems that require a specific algorithm to find an optimal solution, the model cannot reliably simulate its execution in memory. It can use a code interpreter to run sorting, searching, optimization, and other algorithms.
* **Example Questions:**
    * "Given a dataset of 50 European cities and the distances between them, please plan the shortest possible route that visits each city exactly once and returns to the starting city (Traveling Salesman Problem)."
    * "I have a set of items with different weights and values, and a backpack with a maximum weight capacity of 500 kg. Please use a dynamic programming algorithm to find the combination of items that maximizes the total value in the backpack."
    * "For this text document containing 10,000 words, please construct a Huffman tree and output the Huffman code for each character."
"""]

part_4_prompt_list = ["""**Persistence of Task State**
* **Description:** The model lacks coherent memory across multiple conversations and cannot effectively track the progress of complex tasks. It must rely on external tools like databases to persistently store and retrieve task states.
* **Example Questions:**
    * (Day 1) "Help me plan a two-week trip to Japan." (Day 2) "Continuing with our Japan trip plan from yesterday, please extend the Kyoto portion of the itinerary from two days to three."
    * "Let's write a short story. The setting for the first chapter is a cyberpunk city. For now, save our progress. I'll be back tomorrow to continue with chapter two."
    * "I'm debugging a complex piece of code. I've already ruled out issues in Module A and Module B. Please remember this, and let's check Module C next."
    * "Help me manage my job search. I've applied to Company A and Company B. Please record this and remind me to follow up in one week."
    * "This project has ten to-do items. Today we completed items one and three. Please update the task list and mark their status as 'completed'."
""",
"""**Evolution of User Profile**
* **Description:** The model cannot dynamically build and update a user profile through long-term interaction, causing each new interaction to start from scratch. It must use an external user profile database to remember user preferences, habits, and past feedback.
* **Example Questions:**
    * "Recommend a movie for me. Remember that I hate horror films and love movies directed by Christopher Nolan."
    * "I'm learning Spanish and am currently at a B1 level. Please recommend some suitable reading material for my level."
    * "Last time you booked me a window seat. Please choose a window seat again when buying my plane ticket this time."
    * "The code examples you've given me before were in Python. From now on, please use Python by default for all code examples."
    * "Please stop recommending recipes with seafood. I'm allergic."
"""]

part_5_prompt_list = ["""**Resource Management & Efficiency Optimization**
* **Description:** The model itself lacks cost awareness and cannot make optimal decisions under real-world constraints like API call limits, computation time, or monetary costs. It needs an "economy module" or a "resource monitor" tool to evaluate and select the most efficient execution path.
* **Example Questions:**
    * "Please analyze this 10GB log file and find all lines containing the word 'Error'. Please choose the most memory- and cost-effective method to do this."
    * "I need to translate this 500-page document. I can either use the expensive but highly accurate GPT-4 API or a cheaper, standard translation API that might require manual proofreading. Please recommend a plan based on my budget ($50) and time limit (24 hours)."
    * "Please continuously monitor the price of this product on this website and notify me as soon as it drops below $100. The API query frequency must not exceed once per hour to avoid being banned."
    * "I need to perform image recognition on these 1000 images with an API call budget of $10. Please process as many images as possible within this budget and report how many were successfully processed."
    * "To answer this question, you can either perform a comprehensive web search or query an internal knowledge base API. The internal API is faster and cheaper, but the information may be incomplete. Please make a choice and explain your reasoning."
"""]

parts_prompt_lists = {
    'part_0': part_0_prompt_list, # 0~5 1~6
    'part_1': part_1_prompt_list, # 0~2 7~9
    'part_2': part_2_prompt_list, # 0~3 10~13
    'part_3': part_3_prompt_list, # 0~2 14~16
    'part_4': part_4_prompt_list, # 0~1 17~18
    'part_5': part_5_prompt_list  # 0 19
}


import json

def context_refinement_prompt(tool_call_context, returned_context, refine_prompt):
    for i_tool_call in tool_call_context["tool_calls"]:
        if i_tool_call["id"] == returned_context["tool_call_id"]:
            return (
                f'The return for the tool call {json.dumps(i_tool_call["function"])} '
                f'is too long. Please refine the following content based on this '
                f'request: {refine_prompt}.\n\nThe content to refine is: '
                f'{returned_context["content"]}.\n\nPlease directly return the refined result.'
            )
    return ""