{
  "root": {
    "name": "Add subtitle 'A Comprehensive Study' to the title slide below the main title",
    "description": "Evaluates whether the agent has correctly added the subtitle 'A Comprehensive Study' to the title slide, placed it below the main title, and avoided extraneous changes.",
    "is_critical": true,
    "metadata": {},
    "children": [
      {
        "name": "Subtitle text presence on title slide",
        "description": "Checks that the subtitle 'A Comprehensive Study' exists as a text element on the first slide.",
        "is_critical": true,
        "metadata": {},
        "scorer": {
          "type": "function",
          "function_code": "def compute_score() -> tuple[str, float]:\n    # Use python-pptx to find the text on the first slide\n    from pptx import Presentation\n    prs = Presentation(modified_ppt_path)\n    first_slide = prs.slides[0]\n    target = 'A Comprehensive Study'.lower().strip()\n    found = False\n    for shape in first_slide.shapes:\n        if not shape.has_text_frame:\n            continue\n        text = shape.text_frame.text.lower().strip()\n        if target in text:\n            found = True\n            break\n    if found:\n        return \"Found subtitle text on the title slide.\", 1.0\n    else:\n        return \"Subtitle text not found on the title slide.\", 0.0\n"
        },
        "score": 1.0
      },
      {
        "name": "Subtitle text placement below main title",
        "description": "Checks that the subtitle appears below the main title on the title slide (visually, or by shape order/top coordinates).",
        "is_critical": true,
        "metadata": {},
        "scorer": {
          "type": "function",
          "function_code": "def compute_score() -> tuple[str, float]:\n    from pptx import Presentation\n    prs = Presentation(modified_ppt_path)\n    slide = prs.slides[0]\n    title_shape = None\n    subtitle_shape = None\n    target = 'A Comprehensive Study'.lower().strip()\n    # Find title and subtitle shapes\n    for shape in slide.shapes:\n        if not shape.has_text_frame:\n            continue\n        text = shape.text_frame.text.lower().strip()\n        if shape == slide.shapes.title and text:\n            title_shape = shape\n        if target in text:\n            subtitle_shape = shape\n    if not title_shape or not subtitle_shape:\n        return \"Couldn't locate both title and subtitle shapes.\", 0.0\n    # Check that subtitle is visually below main title\n    title_bottom = title_shape.top + title_shape.height\n    if subtitle_shape.top >= title_bottom:\n        return \"Subtitle is placed below the main title.\", 1.0\n    else:\n        return \"Subtitle is not placed below the main title.\", 0.0\n"
        },
        "score": 1.0
      },
      {
        "name": "No extraneous modifications",
        "description": "Checks that only the intended subtitle addition was performed, with no unrelated text, slide, animation, or transition changes.",
        "is_critical": false,
        "metadata": {},
        "children": [
          {
            "name": "No extraneous slides added or removed",
            "description": "Ensures no slides were added or removed except possibly a subtitle shape.",
            "is_critical": false,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score() -> tuple[str, float]:\n    if ppt_diff.added_slides or ppt_diff.removed_slides:\n        return \"Slides were added or removed, which is extraneous.\", 0.0\n    return \"No slides were added or removed.\", 1.0\n"
            },
            "score": 1.0
          },
          {
            "name": "No extraneous text changes on title slide",
            "description": "Ensures that text changes on the title slide are only related to the subtitle addition.",
            "is_critical": false,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score() -> tuple[str, float]:\n    # We'll check that on the title slide, the only added text is the subtitle itself\n    from pptx import Presentation\n    orig = Presentation(original_ppt_path)\n    mod = Presentation(modified_ppt_path)\n    orig_slide = orig.slides[0]\n    mod_slide = mod.slides[0]\n    # Gather all text on before and after\n    def get_all_text(slide):\n        texts = []\n        for shape in slide.shapes:\n            if shape.has_text_frame:\n                texts.append(shape.text_frame.text.strip())\n        return set(texts)\n    orig_texts = get_all_text(orig_slide)\n    mod_texts = get_all_text(mod_slide)\n    added_texts = [t for t in mod_texts if t not in orig_texts]\n    # Only permitted addition is the exact subtitle\n    allowed = {'A Comprehensive Study'}\n    extraneous = []\n    repeat = False\n    for t in added_texts:\n        if t not in allowed or repeat:\n            extraneous.append(t)\n        if t in allowed:\n            repeat = True\n    if extraneous:\n        return f\"Found extraneous text additions on title slide: {extraneous}\", 0.0\n    return \"No extraneous text additions on title slide.\", 1.0\n"
            },
            "score": 1.0
          },
          {
            "name": "No animations or transitions added to title slide",
            "description": "Ensures no new animations or transitions have been added to the title slide.",
            "is_critical": false,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score() -> tuple[str, float]:\n    # Check for added/removed/modified animations or transitions on slide 0 (title slide)\n    title_slide_id = None\n    if ppt_diff.added_slides:\n        title_slide_id = ppt_diff.added_slides[0].slide_id\n    else:\n        # Try to get from original slides\n        if ppt_diff.removed_slides:\n            title_slide_id = ppt_diff.removed_slides[0].slide_id\n        else:\n            # Fallback: assume first slide in modifications is title slide\n            if ppt_diff.modified_slides:\n                title_slide_id = ppt_diff.modified_slides[0][1].slide_id\n    # If not found, check index 0\n    if not title_slide_id:\n        from pptx import Presentation\n        mod = Presentation(modified_ppt_path)\n        title_slide_id = mod.slides[0].slide_id\n    # Check for any added/removed/modified animations/transitions on that slide\n    for anim in ppt_diff.added_animations + [b for a, b in ppt_diff.modified_animations]:\n        if anim.slide_id == title_slide_id:\n            return \"Animation was added or modified on title slide.\", 0.0\n    for trans in ppt_diff.added_transitions + [b for a, b in ppt_diff.modified_transitions]:\n        if trans.slide_id == title_slide_id:\n            return \"Transition was added or modified on title slide.\", 0.0\n    return \"No animations or transitions added to title slide.\", 1.0\n"
            },
            "score": 1.0
          }
        ],
        "score": 1.0
      }
    ],
    "score": 1.0
  },
  "metadata": {
    "task": "In the title slide, add a subtitle 'A Comprehensive Study' below the main title"
  }
}