---
name: idea-generation
description: "Use this when the user wants research ideas, innovation points, or to find research gaps. Generates 5 ideas from collected papers, identifies gaps, proposes novel methods with citations. Requires papers in workspace."
metadata:
  {
    "agent-runtime":
      {
        "emoji": "💡",
        "requires": { "bins": ["git"] },
      },
  }
---

# Idea Generation

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

Generate research ideas grounded in literature analysis. This skill reads existing papers, identifies research gaps, and produces 5 distinct ideas with citations.

**Core principle:** ideas MUST be grounded in actual papers, not generated from model knowledge alone.

**Workspace:** `$W` = working directory provided in the task parameter. Outputs go to `$W/ideas/`.

---

## Step 1: Check workspace resources

First, check what already exists in `$W`:

```bash
ls $W/papers/ 2>/dev/null | head -20
ls $W/papers/_meta/ 2>/dev/null | head -10
ls $W/survey/ 2>/dev/null
```

### Assess available resources

| Resource | Location | Status |
|----------|----------|--------|
| Papers | `$W/papers/` | Count: ? |
| Survey clusters | `$W/survey/clusters.json` | Exists: Y/N |
| Repos | `$W/repos/` | Count: ? |

---

## Step 2: Ask the user about the search strategy

Based on the workspace state, ask the user:

**If papers exist (≥5):**
> 📚 Found {N} papers in the workspace from a previous survey.
>
> Options:
> 1. **Use existing papers** — generate ideas from the current collection.
> 2. **Search more** — run `/research-collect` to expand the collection.
> 3. **Quick search** — add 5–10 more papers on a specific topic.

**If no papers:**
> 📭 No papers found in the workspace.
>
> To generate grounded ideas, I need literature. Options:
> 1. **Run /research-collect** — comprehensive search (100+ papers, recommended).
> 2. **Quick search** — fetch 10–15 papers on your topic now.
> 3. **You provide papers** — point me to existing PDFs / tex files.

---

## Step 3: Acquire resources (if needed)

### Option A: Delegate to /research-collect (recommended)

If the user wants a comprehensive search:

```
Please run: /research-collect {topic}

This will:
- Search 100+ papers systematically.
- Filter by relevance (score ≥4).
- Cluster into research directions.
- Save to $W/papers/.

After the survey completes, run /idea-generation again.
```

### Option B: Quick search (5–10 papers)

For fast iteration, do a minimal search:

1. **ArXiv search:**
```
Tool: arxiv_search
Arguments:
  query: "{user_topic}"
  max_results: 10
```

2. **Clone 3–5 reference repos:**
```bash
mkdir -p $W/repos
git clone --depth 1 {repo_url} $W/repos/{name}
```

3. **Download paper sources:**
```bash
mkdir -p $W/papers/{arxiv_id}
curl -L "https://arxiv.org/src/{arxiv_id}" | tar -xz -C $W/papers/{arxiv_id}
```

---

## Step 4: Analyze the literature

**Prerequisite:** at least 5 papers in `$W/papers/`.

### 4.1 Read papers

For each paper, extract:

- Core contribution (one sentence).
- Key method / formula.
- Limitations mentioned.
- Future work suggestions.

**Long papers (>50KB):** see `references/reading-long-papers.md`.

### 4.2 Identify research gaps

Look for:

- Common limitations across papers.
- Unexplored combinations of techniques.
- Scalability issues.
- Assumptions that could be relaxed.

Document gaps in `$W/ideas/gaps.md`:

```markdown
# Research gaps identified

## Gap 1: [description]
- Mentioned in: [paper1], [paper2]
- Why important: ...

## Gap 2: [description]
...
```

---

## Step 5: Generate 5 ideas

Create `$W/ideas/idea_1.md` through `idea_5.md` using the template in `references/idea-template.md`.

**Requirements:**

- Each idea cites ≥2 papers by arXiv ID.
- Use a different strategy for each:

| Idea | Strategy |
|------|----------|
| 1 | Combination — merge 2+ techniques |
| 2 | Simplification — reduce complexity |
| 3 | Generalization — extend to a new domain |
| 4 | Constraint relaxation — remove an assumption |
| 5 | Architecture innovation — new design |

**❌ REJECTED if:** no arXiv IDs are cited, or the ideas are not grounded in the literature.

---

## Step 6: Select and enhance the best idea

### 6.1 Score all ideas

| Idea | Novelty | Feasibility | Impact | Total |
|------|---------|-------------|--------|-------|
| 1 | /5 | /5 | /5 | /15 |
| ... | | | | |

### 6.2 Enhance the selected idea

Create `$W/ideas/selected_idea.md` with:

- Detailed math (loss functions, gradients).
- Architecture choices.
- Hyperparameters.
- Implementation roadmap.

### 6.3 (Optional but recommended) OpenReview evidence check

For the top 1–2 shortlisted ideas, validate novelty / positioning risk with `openreview_lookup`:

- Query using core title keywords or a representative baseline paper title.
- Extract evidence:
  - decision (if available)
  - average rating / confidence
  - reviewer weakness patterns
- Add a short "submission risk note" section per idea:
  - likely reviewer concern
  - mitigation experiment to add
  - positioning adjustment

Do not claim accept/reject predictions as facts. Report evidence-backed risk signals only.

---

## Step 7: Code survey

Map idea concepts to reference implementations.

See `references/code-mapping.md` for the template.

**Output:** `$W/ideas/implementation_report.md`

---

## Step 8: Summary

Create `$W/ideas/summary.md`:

- All 5 ideas with scores.
- Selected idea details.
- Next step: `/research-pipeline` to implement.

---

## Commands

| User says | Action |
|-----------|--------|
| "Generate ideas for X" | Check workspace → ask strategy → generate |
| "I have papers, generate ideas" | Skip to Step 4 |
| "Enhance idea N" | Jump to Step 6 |
| "Map to code" | Jump to Step 7 |

---

## Integration

- **Before:** `/research-collect` to collect papers.
- **After:** `/research-pipeline` to implement the selected idea.
- **Alternative:** `/write-review-paper` to write a survey instead.
