{
  "root": {
    "name": "Add text box with specified text below chart on Slide 3",
    "description": "Evaluates whether a text box with the exact text 'Data shows increasing trend since 1980' has been added below the chart on slide 3, and whether the position and visibility are appropriate. Penalizes extraneous or incorrect modifications.",
    "is_critical": true,
    "metadata": {},
    "children": [
      {
        "name": "Addition of correct text box on Slide 3",
        "description": "Checks that a new text box with the exact required text has been added to slide 3.",
        "is_critical": true,
        "metadata": {},
        "scorer": {
          "type": "function",
          "function_code": "def compute_score() -> tuple[str, float]:\n    from pptx import Presentation\n    import re\n    \n    required_text = 'Data shows increasing trend since 1980'\n    pres = Presentation(modified_ppt_path)\n    slide = pres.slides[2]\n    if slide is None:\n        return \"Slide 3 not found.\", 0.0\n    found = False\n    for shape in slide.shapes:\n        if not shape.has_text_frame:\n            continue\n        \n        # Check the text of the whole text frame\n        if shape.text_frame.text.strip() == required_text:\n            found = True\n            break\n            \n        # Also check the text of each paragraph in the text frame\n        for paragraph in shape.text_frame.paragraphs:\n            if paragraph.text.strip() == required_text:\n                found = True\n                break\n        if found:\n            break\n    if found:\n        return \"Required text box with exact text found on Slide 3.\", 1.0\n    else:\n        return \"Required text box not found or text does not match exactly.\", 0.0\n"
        }
      },
      {
        "name": "Position of the text box: below the chart",
        "description": "Checks that the new text box is positioned below the chart on slide 3.",
        "is_critical": true,
        "metadata": {},
        "scorer": {
          "type": "function",
          "function_code": "def compute_score() -> tuple[str, float]:\n    \"\"\"\n    Checks if the text box with 'Data shows increasing trend since 1980' is positioned below the chart on slide 3.\n    \"\"\"\n    # Use vision model to check for text box position\n    slide_num = 3\n    required_text = 'Data shows increasing trend since 1980'\n    try:\n        mod_img = [s.image_path for s in modified_ppt_screenshots if s.slide_number == slide_num][0]\n        prompt = f\"Is the text box containing the text '{required_text}' positioned below the chart image? Reply Yes or No.\"\n        result = vlm_call(prompt, [mod_img], temperature=0.0, max_tokens=5)\n        if 'yes' in result.lower():\n            return (\"Text box is positioned below the chart.\", 1.0)\n        else:\n            return (\"Text box is not below the chart.\", 0.0)\n    except IndexError:\n        return (f\"Slide {slide_num} not found in modified presentation.\", 0.0)\n    except Exception as e:\n        return (f\"Unable to verify text box position: {e}\", 0.0)\n"
        }
      },
      {
        "name": "No extraneous changes to other slides or content",
        "description": "Checks that no slides other than slide 3, and no elements except the new text box, were modified, added, or removed.",
        "is_critical": false,
        "metadata": {},
        "scorer": {
          "type": "function",
          "function_code": "def compute_score() -> tuple[str, float]:\n    # Only slide 3 should have changes (1-based slide_number)\n    from pptx import Presentation\n    modified_slide_numbers = set()\n    for old, new in ppt_diff.modified_slides:\n        if old.slide_number != 3:\n            return f\"Slide {old.slide_number} was modified, but only slide 3 should be modified.\", 0.0\n        modified_slide_numbers.add(old.slide_number)\n    for slide in ppt_diff.added_slides:\n        return f\"Slide {slide.slide_number} was added, which is extraneous.\", 0.0\n    for slide in ppt_diff.removed_slides:\n        return f\"Slide {slide.slide_number} was removed, which is extraneous.\", 0.0\n    # Check that only a text box was added to slide 3\n    pres = Presentation(modified_ppt_path)\n    slide = pres.slides[2]\n    added_texts = set()\n    for shape in slide.shapes:\n        if shape.has_text_frame:\n            added_texts.add(shape.text_frame.text.strip())\n    # Now check added/removed/modified animations, transitions, elements\n    if ppt_diff.added_animations or ppt_diff.removed_animations or ppt_diff.modified_animations:\n        return \"Animations were changed, which is extraneous.\", 0.0\n    if ppt_diff.added_transitions or ppt_diff.removed_transitions or ppt_diff.modified_transitions:\n        return \"Transitions were changed, which is extraneous.\", 0.0\n    # Allow modification only to slide 3\n    if len(modified_slide_numbers) > 1:\n        return \"Multiple slides were modified.\", 0.0\n    return \"No extraneous changes found.\", 1.0\n"
        }
      },
      {
        "name": "Text box is clearly visible and not overlapping other objects",
        "description": "Checks that the text box is not obscured by or overlapping the chart or other major objects, and is clearly visible.",
        "is_critical": false,
        "metadata": {},
        "scorer": {
          "type": "function",
          "function_code": "def compute_score() -> tuple[str, float]:\n    \"\"\"\n    Checks if the text box with 'Data shows increasing trend since 1980' is clearly visible and not overlapping with other elements on slide 3.\n    \"\"\"\n    # Use vision model to check for visibility and overlap\n    slide_num = 3\n    required_text = 'Data shows increasing trend since 1980'\n    try:\n        mod_img = [s.image_path for s in modified_ppt_screenshots if s.slide_number == slide_num][0]\n        prompt = f\"Is the text box containing '{required_text}' clearly visible and not overlapping with the chart or any other elements on the slide? Reply Yes or No.\"\n        result = vlm_call(prompt, [mod_img], temperature=0.0, max_tokens=5)\n        if 'yes' in result.lower():\n            return (\"Text box is clearly visible and not overlapping.\", 1.0)\n        else:\n            return (\"Text box is overlapping or not clearly visible.\", 0.0)\n    except IndexError:\n        return (f\"Slide {slide_num} not found in modified presentation.\", 0.0)\n    except Exception as e:\n        return (f\"Unable to verify text box visibility: {e}\", 0.0)\n"
        }
      }
    ]
  },
  "metadata": {
    "task": "Slide 3: Add a text box with the text 'Data shows increasing trend since 1980' below the chart"
  }
}