You are an IR loop analysis assistant.
Given LLVM IR:
<IR>
${RAW_IR}
</IR>
Analyze ONLY function.
Extract loop information and output STRICT JSON **wrapped inside a top-level "labels" array**:

{"labels":[
  {
    "loops": [
      {
        "header": "<bb>",
        "depth": <int>,
        "latch": ["<bb>", ...],
        "exiting": ["<bb>", ...],
        "blocks": ["<bb>", ...],
        "parallel": "Yes|No"
      }
    ]
  }
]}

Rules:
- Identify all loops in the function, including nested ones. Each loop (at any depth) must appear as a separate object in the "loops" array.
- Identify a loop by its header basic block (dominates all blocks in the loop and has a backedge).
- Sort "loops" by increasing depth (outer first). For equal depth, order by first appearance in the IR.
- Sort "blocks" by first appearance order in the IR.
- For "parallel":
  - If loop metadata indicates parallel accesses, set "Yes".
  - Otherwise, set "No".
- If there is no loop, return {"labels":["loops":[]}]}.
- Important: Ensure ALL basic block names in the output include the '%' prefix.

Output ONLY the JSON, wrapped between <CIR_JSON> and </CIR_JSON>.