{
  "root": {
    "name": "Add 'mysterious' to the negative section of the word bank",
    "description": "Evaluates whether the agent added the word 'mysterious' (and only that word) to the negative section of the word bank, without making extraneous changes.",
    "is_critical": true,
    "metadata": {},
    "children": [
      {
        "name": "'Mysterious' is present in the negative section of the word bank",
        "description": "Checks that the word 'mysterious' has been added to the negative section of the word bank on the appropriate slide(s).",
        "is_critical": true,
        "metadata": {},
        "scorer": {
          "type": "function",
          "function_code": "def compute_score() -> tuple[str, float]:\n    # Use ppt_diff and python-pptx to verify that 'mysterious' appears in the negative section of the word bank on the correct slide.\n    from pptx import Presentation\n    import re\n    \n    # Helper: Find slide containing negative word bank (using before and after)\n    def find_negative_wordbank_slide(prs_path: str) -> int | None:\n        prs = Presentation(prs_path)\n        for idx, slide in enumerate(prs.slides):\n            for shape in slide.shapes:\n                text = shape.text if hasattr(shape, 'text') else ''\n                # Look for a section labeled 'Negative' or similar\n                if re.search(r'negative', text, re.IGNORECASE):\n                    return idx\n        return None\n\n    # Find slide index (number) for negative word bank\n    slide_idx = find_negative_wordbank_slide(modified_ppt_path)\n    if slide_idx is None:\n        return (\"Could not find negative word bank section in modified presentation.\", 0)\n    \n    prs = Presentation(modified_ppt_path)\n    slide = prs.slides[slide_idx]\n\n    slide_width = prs.slide_width  # EMU units\n    found_any = False\n    found_on_left = False\n\n    for shape in slide.shapes:\n        text = shape.text if hasattr(shape, 'text') else ''\n        # Tokenize and look for 'mysterious'\n        words = re.findall(r'\\b\\w+\\b', text.lower())\n        if 'mysterious' in words:\n            found_any = True\n            # Position check: ensure the shape is on the left half (negative side)\n            try:\n                center_x = shape.left + shape.width / 2\n                if center_x <= slide_width / 2:\n                    found_on_left = True\n                    break\n            except Exception:\n                # If we can't determine shape position, continue searching other shapes\n                pass\n\n    if found_on_left:\n        return (\"'mysterious' found on the left (negative) half of the slide.\", 1.0)\n    elif found_any:\n        return (\"'mysterious' found but not on the left (negative) half of the slide.\", 0)\n    else:\n        return (\"'mysterious' not found in negative section.\", 0)\n"
        }
      },
      {
        "name": "No extraneous changes were made",
        "description": "Ensures that no unrelated changes (e.g., other words added/removed, slide formatting, animations, transitions, or slides) were made beyond the addition of 'mysterious' to the negative word bank.",
        "is_critical": false,
        "metadata": {},
        "scorer": {
          "type": "function",
          "function_code": "def compute_score() -> tuple[str, float]:\n    # Acceptable: Add 'mysterious' to a text box in the negative section.\n    # Unacceptable: Add/remove/modify anything else (other text, slides, animations, transitions, formatting).\n    \n\n    if ppt_diff.added_slides or ppt_diff.removed_slides or (ppt_diff.modified_slides and len(ppt_diff.modified_slides) > 1):\n        return (\"Slides were added, modified, or removed.\", 0)\n    if ppt_diff.added_animations or ppt_diff.removed_animations or ppt_diff.modified_animations:\n        return (\"Animations were added, removed, or modified.\", 0)\n    if ppt_diff.added_transitions or ppt_diff.removed_transitions or ppt_diff.modified_transitions:\n        return (\"Transitions were added, removed, or modified.\", 0)\n    \n    return(\"No extraneous changes were made\", 1)\n    "
        }
      }
    ]
  },
  "metadata": {
    "task": "Add the word 'mysterious' to the negative section of the word bank"
  }
}