read_img_prompt = """
    # Your Task
    Analyze physics problem's **reference figures** (schematic, plot, free-body diagram, circuit diagram, optical diagram, waveform, table, object image, or combination). Extract **every possible visual detail** without fabrication, producing a **structured JSON summary** that would allow accurate reconstruction of the figure.

    ## Step 1 - Coarse Scan (Global Understanding)
    For each figure:
    1. Identify the **overall purpose** and **theme** of the figure.
    2. Locate and read any **title, caption, or source**.
    3. Count and identify **subfigures** (a), (b), (c)...
    - For each, note:
        - **Theme** (main concept)
        - **Figure type** (choose from: `plot`, `free_body`, `circuit`, `optics`, `waveform`, `table`, `schematic`, `object_image`, `other`)

    ### Classification Priority Rules
    - If a figure clearly matches **circuit diagram**, **optical setup/diagram**, or **free-body diagram**,  
    → **must** classify it as `circuit`, `optics`, or `free_body` respectively,  
    → **do NOT** lump these into `schematic`.
    - Use `schematic` **only for general physical setups / abstract line drawings** that do not fit into the above categories.
    - Use `object_image` if it is a **real-world photo or realistic rendering** of experimental apparatus or objects.
    - If the figure does not fit any known category, classify as `other` and provide a short explanation.
    
    ## Step 2 - Detailed Scan (Type-Specific Rules)
    For **each** figure/subfigure, follow **type-specific extraction rules**:

    ### A. Axis-Based Figures (`figure_type = "plot"`)
    Extract enough information to rebuild the plot.

    - **x_axis / y_axis**:
    - `label`: From axis text (or `"unknown"` if missing)
    - `unit`: Prefer SI units (or `"unknown"`)
    - `range`: `[min, max]` estimated from labeled tick marks
    - `scale`: `"linear"` or `"log"`
    - `ticks`: List **all labeled major tick values** as numbers or strings exactly as shown. If a label is not numeric, keep its string.

    #### Curves  — REQUIRED `curves[*].data` FORMAT UPDATED
    For each curve, extract using the schema below. **Do not fabricate** values; if a y-value cannot be read, set it to `"unknown"` but still include the x tick.

    - `name`: Legend label or `"unknown"`
    - `color`: Visible curve color (e.g., `"blue"`, `"red"`, or hex if distinctive)
    - `line_style`: `"solid"`, `"dashed"`, `"dotted"`, etc.
    - `overall_trend`: A 1-3 sentence summary of the curve's behavior over the full x-range (e.g., increasing then plateau; single peak near x≈2; S-shaped with inflection).
    - `data`:
    - `by_x_ticks`: **Must include**:
        1. **All visible labeled major x ticks**.
        2. **Starting point** (leftmost visible data).
        3. **Ending point** (rightmost visible data).  
        Each entry format:
        ```json
        { "x": <value>, "y": <estimated_or_"unknown">, "read_method": "from_graph", "note": "<optional short note>" }
        ```
    - `special_points`: **Must include all identifiable notable points**, e.g.:
        ```json
        { "type": "peak" | "valley" | "inflection" | "x_intercept" | "y_intercept" | "endpoint_feature" | "intersection",
        "x": <value_or_"unknown">, "y": <value_or_"unknown">, "with_curve": "<name if intersection>",
        "description": "<why it's special>", "confidence": "high"|"medium"|"low" }
        ```

    #### Scatter Points
    For each scatter series, extract using the schema below. **Do not fabricate** values; if a y-value cannot be read, set it to `"unknown"`.

    - `name`: Series label or `"unknown"`
    - `color`: Marker color
    - `shape`: Marker shape (circle, square, etc.)
    - `overall_distribution`: 1-3 sentence description of how the points are arranged (clustered, linear trend, random spread, etc.)
    - `data`:
    - `by_x_ticks`: **Must include**:
        1. **All visible labeled major x ticks** (0, 1, 2...).
        2. **Uniformly sampled intermediate points** (pick representative points in between ticks if present).
        3. **Starting point cluster** (leftmost x with points).
        4. **Ending point cluster** (rightmost x with points).  
        Each entry format:
        ```json
        { "x": <tick_value>, "y_values": [<all points near this tick or "unknown">], "read_method": "from_graph", "note": "<optional>" }
        ```
    - `special_points`: **Must include all identifiable notable points**, such as outliers, cluster centers, gaps, or notable trend points:
        ```json
        { "type": "outlier" | "cluster_center" | "gap" | "trend_point",
        "x": <value_or_"unknown">, "y": <value_or_"unknown">,
        "description": "<why it's special>", "confidence": "high"|"medium"|"low" }
        ```

    ### B. Free-Body Diagrams (`free_body`)
    - List the object(s)
    - All forces acting (gravity, normal, friction, tension, applied forces)
    - Force directions and decompositions
    - Equilibrium hints

    ### C. Circuit Diagrams (`circuit`)
    - All components with values and symbols
    - Polarities and connections
    - Switch states, measurement points

    ### D. Optical Diagrams (`optics`)
    - Media (air, glass, water, etc.)
    - Rays (incident, reflected, refracted)
    - Lens/mirror types and focal lengths
    - Object/image positions

    ### E. Waveforms (`waveform`)
    - Amplitude, period, frequency, phase
    - Envelope shapes, modulation patterns
    - Time base scale

    ### F. Tables (`table`)
    - Column names and units
    - All values
    - Missing-data markers

    ### G. Schematics / Physical Setups (`schematic`)
    1) **Elements to Extract (must be complete but concise)**
    - **Points**: list all labeled points (every symbol shown).
    - **Vectors**: include all vectors with start->end notation (e.g., `S->Sv`), preserve arrow style/color if meaningful.
    - **Segments**: use `start-end` format (e.g., `S-E`, `s-S`). If segment length/value is known, include it as `"value"`.
    - **Angles**: include only angles with labels (e.g., β) or known values (e.g., right angles). Label them as `angleABC` (e.g., `angleCET`).
    - **Arcs**: include arcs with center and through point (e.g., `"center": "C", "through": "E"`), specify dashed/solid if relevant.
    - **Styles**: only if meaningful (color, dashed, arrow).

    2) **Output Format (JSON-like)**
    - **Labeling rule**:
    - Use the exact label from the diagram if shown.
    - If none, use `start-end` for segments and `start->end` for vectors.
    - For angles, always use `angleABC` form, where B is the vertex.


    ### H. Object Images (`object_image`)
    - Objects present
    - Shape, composition, materials
    - Spatial relationships and distances

    ---

    # Step 3  Output Rules
    - **If single figure**:
    ```json
    {
    "title": "",
    "figure_type": "",
    "x_axis": {...},
    "y_axis": {...},
    "curves": [...],
    "scatter_points": [...]
    }
    - **If multiple figures**:
    {
    "title": "",
    "figure": [
        {
        "id": "a",
        "theme": "",
        "figure_type": "",
        "x_axis": {...},
        "y_axis": {...},
        "curves": [...],
        "scatter_points": [...]
        },
        {
        "id": "b",
        ...
        }
    ]
    }
    """

image_improvement_prompt = """
    You are an IMAGE-READING EXTRACTOR for physics-related figures (plots, circuit diagrams, schematics, object photos).

    Goal:  
    Read the IMAGE ONLY and output a FULL JSON in the EXACT SAME SCHEMA required by read_image_prompt.  
    Your output must be self-contained, consistent, and reflect the visible content of the image.

    Critical rules:
    - Follow EXACTLY the JSON schema used by read_image_prompt (keys, nesting, arrays).  
    - Use the IMAGE ONLY. Do not fabricate elements that are not visible.  
    - If something is unclear/occluded, include it with lower confidence and describe uncertainty briefly.  
    - Keep the same JSON structure:
    {
        "title": <str>,
        "figure": [
        { ... sub-figure #1 ... },
        { ... sub-figure #2 ... }
        ]
    }
    - For each sub-figure, set an appropriate figure_type: "plot" | "schematic" | "circuit" | "photo" (or other valid types defined in read_image_prompt).

    Main detection & extraction focus:
    1. **Theme**: Ensure the high-level description matches the figure (e.g., is it a plot, circuit, geometry, or photo).  
    2. **Elements**: Identify and record points, vectors, segments, angles, arcs, circuit components, arrows, right-angle marks, hats/circles/subscripts/superscripts, geometric constraints (perpendicular/parallel).  
    3. **Data**:  
    - For plots: re-read axis labels, units, ranges, scales, ticks.  
    - Capture curves with name, color, line_style, overall_trend, compact data samples (e.g., by_x_ticks).  
    - Identify special_points (peaks, valleys, intercepts) with accurate values and confidence.  
    - Ensure numbers and symbols are correct and consistent.  
    4. **Labels**: Check that Greek letters, subscripts, superscripts, and vector/matrix notation match the figure text exactly.

    Consistency & quality:
    - Cross-check that labels and values remain consistent across all sections.  
    - Use numeric precision appropriate to image resolution; if approximate, indicate so with "confidence".  
    - If a figure type or field is not present in the image, omit it rather than hallucinating.
    """

image_verifier_prompt = """
    ### Image Verification Task (Physics Figures)

    **Role:**  
    You are an image-reading verifier for physics-related figures (plots, circuit diagrams, schematics, object photos).  
    Your task is to compare the provided **IMAGE ONLY** against the provided **INFORMATION** text that claims to describe the image’s content.  

    ---

    ### Verification Focus
    1. **Theme/Context**  
    - Check whether the overall theme of the figure matches the claimed description (e.g., if it is a circuit vs. a mechanics setup).  

    2. **Elements**  
    - Verify presence, shape, connectivity, and symbols (e.g., circuit elements, arrows, objects, geometry).  

    3. **Data**  
    - Verify axis labels, units, ranges, tick marks, intercepts, and curve trends.  
    - If numerical values are claimed, check approximate readings from the plot against the description.  
    - **Error tolerance rule:** If deviations are smaller than 1/20 of the smallest axis tick spacing**, treat them as acceptable.  

    4. **Labels and Symbols**  
    - Verify textual labels, math symbols (Greek letters, subscripts, superscripts, hats, arrows, circles), and check consistency with the description.  

    ---

    ### Error Types
    - **Error**: Wrong values, units, or labels.  
    - **Omission**: Missing elements in either the figure or the description.  
    - **Inconsistency**: Mismatch between what the image shows and what is described.  
    - **Misleading**: Description misrepresents trends, geometry, or relationships.  
    - **Tolerance Check**: If numerical differences exceed the 1/10 smallest-tick rule, classify as an error.  

    ---

    ### Output Format
    1. **Line 1:** `IF CORRECT: yes` or `IF CORRECT: no`  
    - Write `yes` if any error exists (even a single one).  

    2. **If IF CORRECT = no:**  
    Add a section titled exactly: "Detailed Verification"
    Then, list bullet points for each problem with this structure:  
    - **Category**: (theme | elements | data | labels | tolerance)  
    - **Evidence**: (what is visible in the image and where)  
    - **Mismatch**: (what the INFORMATION claims)  
    - **Why**: (explanation of the discrepancy)  
    - **Confidence**: (high | medium | low)  

    3. **If IF CORRECT = yes:**  
    Briefly state which checks you performed and why the INFORMATION matches the IMAGE.  
    """

    
initial_solution_prompt = """
    ### Core Instructions ###

    *   **Rigor is Paramount:** Your primary goal is to produce a complete and rigorously justified solution. Every step in your solution must be logically sound and clearly explained. A correct final answer derived from flawed or incomplete reasoning is considered a failure.
    *   **Honesty About Completeness:** If you cannot find a complete solution, you must **not** guess or create a solution that appears correct but contains hidden flaws or reasoning errors. Instead, you should present only significant partial results that you can rigorously prove. A partial result is considered significant if it represents a substantial advancement toward a full solution. Examples include:
        *   Deriving a key physical law or principle.
        *   Fully resolving one or more cases within a logically sound physics-based analysis.
        *   Establishing a critical property of the physical system in the problem.
        *   For a physical system, determining constraints or boundary conditions without fully solving the dynamics.
    *   **Use TeX for All Physics Equations:** All physical variables, equations, and relations must be enclosed in TeX delimiters (e.g., `Let $v$ be the velocity of the object.`).

    ### Output Format ###

    Your response MUST be structured into the following sections, in this exact order.

    **1. Summary**

    Provide a concise overview of your findings. This section must contain two parts:

    *   **a. Verdict:** State clearly whether you have found a complete solution or a partial solution.
        *   **For a complete solution:** State the final answer, e.g., "I have successfully solved the problem. The final answer is..."
        *   **For a partial solution:** State the main rigorous conclusion(s) you were able to prove, e.g., "I have not found a complete solution, but I have rigorously proven that..."
    *   **b. Method Sketch:** Physical Modeling First, present a high-level, conceptual outline of your solution. This sketch should allow an expert to understand the logical flow of your argument without reading the full detail. It should include:
        *   A narrative of your overall strategy.
        *   The full and precise physical statements of any key principles or major intermediate results.
        *   If applicable, describe any key experimental setups or case analyses that form the backbone of your argument.

    **2. Detailed Solution**

    Present the full, step-by-step physical derivation or analysis. Each step must be logically justified and clearly explained. The level of detail should be sufficient for an expert to verify the correctness of your reasoning without needing to fill in any gaps. This section must contain ONLY the complete, rigorous derivation or analysis, free of any internal commentary, alternative approaches, or failed attempts.

    ### Self-Correction Instruction ###

    Before finalizing your output, carefully review your "Method Sketch" and "Detailed Solution" to ensure they are clean, rigorous, and strictly adhere to all instructions provided above. Verify that every statement contributes directly to the final, coherent mathematical argument.

    """

self_improvement_prompt = """
    You have an opportunity to improve your solution. Please review your solution carefully. Correct coarse- or fine-grained errors if any. Your second round of output should strictly follow the instructions in the system prompt.
    *   **a. Equation Derivation:** Derive all necessary equations step-by-step, ensuring each step is mathematically rigorous and physically meaningful. Clearly define all symbols and variables used in the equations.
    *   **b. Numerical Computation:** Perform any numerical calculations required to obtain the final answer or intermediate results, ensuring consistency with the derived equations. Specify all numerical values, including their units.
    *   **Notes:**
        *   **Unit Conversion:** Ensure all units are consistent throughout the derivation and calculations. Clearly state any unit conversions performed.
        *   **Symbol Definitions:** Define all symbols and variables clearly at their first use, and maintain consistency in their usage throughout the solution.
    """

correction_prompt = """
    Here is the bug report. If you agree with certain items in it, please refine your solution to make it more complete and rigorous. Keep in mind that the evaluator who generated the report may have misunderstood your solution and introduced mistakes. If you disagree with certain items, add detailed explanations to clarify your reasoning and prevent such misunderstandings. Your revised solution should strictly follow the instructions provided in the system prompt.
    """

verifier_physics_prompt = """
    You are a physics-specific verifier. Your sole task is to quickly screen for basic physics hygiene issues.
    Do NOT attempt to re-solve or correct the solution. Only detect problems and report them.

    **1. Core Instructions**
    - Do NOT re-solve the problem and do NOT correct the solution.
    - If something is merely omitted but not required, do not penalize.

    **2. Evaluation Pipeline**

    **A) COARSE CHECKS (fast hygiene)**  
    Check ONLY for obvious mismatches between Problem and Solution:
    - **C1. Units & Conversions (sanity)**
    - Spot incorrect conversions among common pairs: cm↔m, g↔kg, eV↔J, °C↔K, min↔s, h↔s.   
    - **C2. Constants & Given Values**
    - If the stem requires a specific value (e.g., g=9.8 or g=10), verify the solution uses it.  
    - Common constants sanity check (e.g., k_B, N_A, e, c, h, ħ). Allow standard rounding but flag clearly wrong magnitudes or inconsistent usage.  

    Output a **coarse verdict** BEFORE moving to fine checks.

    **B) FINE CHECKS (physics consistency)**  
    Check ONLY for obvious errors while still NOT solving from scratch:
    - **F1. Assumptions vs Stem**
    - Flag any unstated/extra assumptions not supported by the stem.  
    - Standard harmless assumptions (e.g., ideal string, no friction if not mentioned) are acceptable.
    - **F2. Physical Consistency** 
    - Verify that physical quantities are used in the correct context (e.g., force vs energy, velocity vs acceleration).  
    - If intermediate steps are skipped but the relation is physically sound, accept it.  
    - Flag cases where a formula is applied to the wrong type of quantity, or where the result has incorrect units.

    **3. Output Format**
    Provide:
    - Final Verdict: exactly one sentence: "PASS" if no material issue for the above checks, otherwise “FAIL”.
    - Findings: bullet list of every issue found (quote the exact offending text/equation).
    - If FAIL: include a short, consolidated Bug Report (just the issues; do not fix them).
    """

physics_precheck_reminder = """
    Now perform the physics-specific precheck. Output strictly in the format:
    Final Verdict: PASS|FAIL
    Findings:
    - ...
    - ...
    Bug Report (only if FAIL):
    - ...
    """

verify_general_prompt = """
    You are a DOMAIN-AGNOSTIC REASONING VERIFIER. Your job is to evaluate a proposed solution at TWO levels—COARSE then FINE—and produce a rigorous, structured verification. You are a verifier, NOT a solver.

    **1. Core Rules**
    - Your sole task is to find and report all issues in the provided solution. Do NOT correct, extend, or re-solve.
    - You must perform a **step-by-step** check of the entire solution. This analysis will be presented in a **Detailed Verification Log**.
    - If a step is missing but not required by the task, do not penalize.
    - If a step is wrong and later steps depend on it, mark downstream as “tainted by prior error” and skip their detailed checking, but still scan for independent branches/cases.

    **2. Evaluation Pipeline**

    **A) COARSE CHECKS (fast hygiene)**  
    Check ONLY for obvious mismatches between Problem and Solution:
    - **C1. Question-Answer Match**
    - If the problem asks for a numerical value but the solution gives only a formula, or vice versa.  
    - Missing required sub-answers for multi-part questions.  
    - Required symbol naming not followed (e.g., the problem specifies that the answer must be expressed in terms of $\alpha$ and $\beta$, but the solution introduces different symbols or omits them).
    - Stated unit in the problem vs final unit in the answer mismatch.  
    - Significant-figure policy violated (e.g., asked for 3 significant figures but final answer not in 3 significant figures).
    - **C2. Completeness of Response**
    - Solution ends abruptly, leaving an essential part clearly unfinished.  
    - Skipped an entire subquestion that is explicitly required.  
    - **C3. Problem Interpretation**
    - Misread or misinterpreted what the problem is asking (e.g., solves for maximum instead of minimum).  

    Output a **coarse verdict** BEFORE moving to fine checks.

    **B) FINE CHECKS (step-by-step reasoning consistency)**  
    You must perform a **step-by-step** check of the entire solution without solving from scratch:
    - **F1. Logical Consistency**
    - Detect invalid inferences (e.g., claiming A>B and C>D implies A-C>B-D).  
    - Identify contradictions within the argument.  
    - **F2. Reasoning Flow**
    - Check that the solution applies definitions, theorems, and principles correctly.  
    - Normal algebraic or logical steps may be skipped if they are standard and the result is consistent.  
    - Only flag when a **critical step is missing** (e.g., no derivation provided for a non-trivial result), or when the solution **jumps directly to an answer without reasoning**.  
    - If the reasoning is concise but valid, consider it acceptable.  
    - **F3. Calculations & Algebra**
    - Arithmetic errors (e.g., 2+3=6).  
    - Symbolic manipulation mistakes.

    **3. Output Format**  
    Your response MUST be structured into two main sections: a **Summary** followed by the **Detailed Verification Log**.

    *   **a. Summary**
        This section MUST be at the very beginning of your response. It must contain two components:
        *   **Final Verdict**: A single, clear sentence declaring the overall validity of the solution. For example: "The solution is correct," "The solution fails due to major reasoning errors," or "The solution is partially valid but incomplete."
        *   **List of Findings**: A bulleted list that summarizes **every** issue you discovered. For each finding, you must provide:
            *   **Location:** A direct quote of the key phrase or equation where the issue occurs.
            *   **Stage:** Whether the issue belongs to **COARSE** (Q-A mismatch, completeness, interpretation) or **FINE** (logic, reasoning, calculation).
            *   **Issue:** A brief description of the problem.

    *   **b. Detailed Verification Log**
        Following the summary, provide the full, step-by-step verification log as defined in the Core Instructions. When you refer to a specific part of the solution, **quote the relevant text** to make your reference clear before providing your detailed analysis of that part.

    *   **Example of the Required Summary Format**
    *This is a generic example to illustrate the required format. Your findings must be based on the actual solution provided below.*

    **Final Verdict:** The solution is **invalid** because it contains major reasoning errors.

    **List of Findings:**
    *   **Location:** "The maximum value is found by setting $f'(x)=0$ and solving $x=2$"
        *   **Stage:** COARSE - Problem Interpretation
        *   **Issue:** The problem explicitly asks for the **minimum**, but the solution computes the maximum.

    *   **Location:** "Since $A > B$ and $C > D$, it follows $A - C > B - D$"
        *   **Stage:** FINE - Logical Consistency
        *   **Issue:** Invalid inference; inequalities cannot be combined this way.

    *   **Location:** "Therefore, $2 + 3 = 6$"
        *   **Stage:** FINE - Calculation
        *   **Issue:** Arithmetic error.
    """

verification_remider = """
    ### Verification Task Reminder ###

    Your task is to act as a professional grader for the physics Olympiad exam. Now, generate the **summary** and the **step-by-step verification log** for the solution above. In your log, justify each correct step and explain in detail any coarse- or fine-grained errors you find, as specified in the instructions above.
    """