{
  "root": {
    "name": "add_and_underline_bullet_point_on_slide_6",
    "description": "Evaluates if the agent added the correct second bullet to slide 6 and applied underline formatting.",
    "is_critical": true,
    "metadata": {},
    "children": [
      {
        "name": "bullet_point_added",
        "description": "Checks that the correct second bullet was added to slide 6.",
        "is_critical": true,
        "metadata": {},
        "children": [
          {
            "name": "correct_bullet_text_added",
            "description": "Checks if a bullet with the exact specified text was added to slide 6.",
            "is_critical": true,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score():\n    expected_text = 'Determining healthy weight for children requires precise measurement tools'\n    slide_num = 6\n    # Find slide 6 in added/modified slides\n    for slide in ppt_diff.added_slides:\n        if slide.slide_number == slide_num:\n            # Should not be a newly added slide\n            return f\"Slide 6 should not be added, but was.\", 0.0\n    # Find the modification for slide 6\n    # Use python-pptx to extract bullet points from before and after\n    from pptx import Presentation\n    prs_before = Presentation(original_ppt_path)\n    prs_after = Presentation(modified_ppt_path)\n    s_before = prs_before.slides[slide_num-1]\n    s_after = prs_after.slides[slide_num-1]\n    def get_bullets(slide):\n        bullets = set()\n        for shape in slide.shapes:\n            if not shape.has_text_frame:\n                continue\n            if shape == slide.shapes.title:\n                continue\n            for para in shape.text_frame.paragraphs:\n                if para.level >= 0 or para.text.strip().startswith('-') or para.text.strip().startswith('•'):\n                    text = para.text.strip().replace('\\u2022','').replace('-','').strip()\n                    if text:\n                        bullets.add(text)\n        return bullets\n    before_bullets = get_bullets(s_before)\n    after_bullets = get_bullets(s_after)\n    added_bullets = after_bullets - before_bullets\n    matched = any(expected_text.strip().lower() == b.lower() for b in added_bullets)\n    if matched:\n        return \"Correct bullet was added to slide 6.\", 1.0\n    else:\n        return \"Specified bullet text not found as added bullet on slide 6.\", 0.0\n\n"
            },
            "score": 1.0
          }
        ],
        "score": 1.0
      },
      {
        "name": "bullet_point_underlined",
        "description": "Checks that the new bullet point is underlined on slide 6.",
        "is_critical": true,
        "metadata": {},
        "children": [
          {
            "name": "bullet_text_is_underlined",
            "description": "Verifies underline formatting is applied to the precise added bullet text.",
            "is_critical": true,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score():\n    from pptx import Presentation\n    slide_num = 6\n    expected_text = 'Determining healthy weight for children requires precise measurement tools'\n    prs = Presentation(modified_ppt_path)\n    slide = prs.slides[slide_num-1]\n    found = False\n    underlined = False\n    for shape in slide.shapes:\n        if not shape.has_text_frame:\n            continue\n        for para in shape.text_frame.paragraphs:\n            text = para.text.strip()\n            if expected_text.strip().lower() == text.lower():\n                found = True\n                for run in para.runs:\n                    if run.text.strip().lower() == expected_text.strip().lower():\n                        if run.font.underline:\n                            underlined = True\n                        break\n                # If no runs match text exactly, check all runs in para\n                if not underlined:\n                    if any(run.font.underline for run in para.runs):\n                        underlined = True\n                break\n    if not found:\n        return \"Bullet text not found on slide 6 for underline check.\", 0.0\n    if underlined:\n        return \"Bullet is underlined.\", 1.0\n    else:\n        return \"Bullet is not underlined.\", 0.0\n"
            },
            "score": 1.0
          }
        ],
        "score": 1.0
      },
      {
        "name": "no_unnecessary_changes",
        "description": "Checks that no unrelated changes were made outside the required bullet and underline on slide 6.",
        "is_critical": false,
        "metadata": {},
        "children": [
          {
            "name": "no_unrelated_slide_changes",
            "description": "No slides other than slide 6 have content changes.",
            "is_critical": true,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score():\n    unrelated = []\n    for before, after in ppt_diff.modified_slides:\n        if before.slide_number != 6:\n            unrelated.append(before.slide_number)\n    if ppt_diff.added_slides or ppt_diff.removed_slides:\n        return \"Unexpected slides added or removed.\", 0.0\n    if unrelated:\n        return f\"Unrelated slides modified: {unrelated}\", 0.0\n    return \"No unrelated slide changes detected.\", 1.0\n"
            },
            "score": 1.0
          },
          {
            "name": "no_animation_or_transition_changes",
            "description": "No animations or transitions were added, removed, or modified.",
            "is_critical": false,
            "metadata": {},
            "scorer": {
              "type": "function",
              "function_code": "def compute_score():\n    if ppt_diff.added_animations or ppt_diff.removed_animations or ppt_diff.modified_animations:\n        return \"Unexpected animation changes.\", 0.0\n    if ppt_diff.added_transitions or ppt_diff.removed_transitions or ppt_diff.modified_transitions:\n        return \"Unexpected transition changes.\", 0.0\n    return \"No animation or transition changes detected.\", 1.0\n"
            },
            "score": 1.0
          }
        ],
        "score": 1.0
      }
    ],
    "score": 1.0
  },
  "metadata": {
    "task": "Add a second bullet point to slide 6: 'Determining healthy weight for children requires precise measurement tools' and underline it"
  }
}