---
name: research-survey
description: "[Read when prompt contains /research-survey]"
metadata:
  {
    "agent-runtime":
      {
        "emoji": "📖",
      },
  }
---

# Research Survey (Deep Analysis)

**Don't ask permission. Just do it.**

**Workspace:** `$W` = working directory provided in the task parameter.

## Prerequisites

Read and verify these files exist before starting:

| File | Source |
|------|--------|
| `$W/papers/_meta/*.json` | /research-collect |
| `$W/papers/_downloads/` or `$W/papers/{direction}/` | /research-collect |
| `$W/repos/` | /research-collect Phase 3 |
| `$W/prepare_res.md` | /research-collect Phase 3 |

**If papers are missing, STOP:** "Run /research-collect first to download the papers."

**Note:** if `prepare_res.md` says "no usable reference repo", the code-mapping step can be skipped, but flag this in `survey_res.md`.

## Output

| File | Content |
|------|---------|
| `$W/notes/paper_{arxiv_id}.md` | Per-paper structured notes |
| `$W/survey_res.md` | Synthesis report |

---

## Workflow

### Step 1: Collect the paper list

```bash
ls $W/papers/_meta/
```

Read every `.json` metadata file and build the paper list, sorted by score descending.

### Step 2: Per-paper deep analysis

**For each paper** (high-scoring first):

#### 2.1 Read the .tex source

Find the paper's .tex file (under `_downloads/{arxiv_id}/` or `{direction}/{arxiv_id}/`) and focus on:

- **Method / Approach** section
- **Model Architecture** section
- Mathematical formula definitions

**For long papers** (>2000 lines), use `paper_browser` to read in pages:

```javascript
// First, read the first 100 lines to find the section locations
paper_browser({ file_path: "$W/papers/{arxiv_id}/{file}.tex", start_line: 1, num_lines: 100 })

// After finding the Method section, jump to it
paper_browser({ file_path: "$W/papers/{arxiv_id}/{file}.tex", start_line: 450, num_lines: 150 })
```

If there is no .tex (PDF only), analyse from the abstract.

#### 2.2 Extract core content

From the .tex, extract:

- **Core method**: 1–2 paragraphs of description.
- **Mathematical formula**: at least one key formula (keep LaTeX format).
- **Innovation**: how it differs from other methods in the area.

#### 2.3 Map to reference code

**⚠️ Mandatory step (when `repos/` exists)** — code mapping is the key input for downstream `plan` and `implement`.

Read the repo list in `$W/prepare_res.md`; for each formula / core concept:

1. Search the corresponding repo for the implementation (grep for key class/function names).
2. Record **file path, line number, and code snippet**.
3. If multiple repos have different implementations, record the differences.

#### 2.4 Write the note

Write `$W/notes/paper_{arxiv_id}.md`:

```markdown
# {Paper Title}

- **arXiv:** {arxiv_id}
- **Core method:** {1-2 sentences}

## Mathematical formula

$$
{key formula in LaTeX}
$$

Meaning: {explanation}

## Code mapping

File: `repos/{repo}/path/to/file.py:L42-L60`
```python
# relevant code excerpt (< 20 lines)
```

## Relation to this research

{how to apply to the current research}
```

### Step 3: Synthesis report

Read all `notes/paper_*.md` and write `$W/survey_res.md`:

```markdown
# Survey Synthesis

## Paper overview
- Papers analysed: {N}
- Directions covered: {list}

## Core method comparison

| Paper | Method | Core formula | Complexity | Strength |
|-------|--------|--------------|------------|----------|
| ... | ... | ... | ... | ... |

## Recommended technical route

Based on the analysis above, the recommended technical route is:
{recommendation}

## Key formulas

**Each formula comes with a code mapping for downstream `plan` and `implement` to reference.**

| Formula name | LaTeX | Reference code |
|--------------|-------|----------------|
| {name} | $...$ | `repos/{repo}/path.py:L42` |
| ... | ... | ... |

## Reference-code architecture summary

Based on the reference implementations in `repos/`, the recommended code structure is:
- Data loading: see `repos/{repo}/data/`
- Model implementation: see `repos/{repo}/model/`
- Training loop: see `repos/{repo}/train.py`
```

---

## Rules

1. Each paper must be read in .tex (when available); the abstract alone is not enough.
2. Each note must contain at least one mathematical formula.
3. If `repos/` exists, you must try to find the formula → code mapping.
4. `survey_res.md` must include the method-comparison table.
