---
name: metabolism
description: "Knowledge metabolism cycle: ingest new papers, update knowledge state, detect cross-topic links, generate hypotheses. Use /metabolism to trigger manually."
user-invokable: true
---

# Continuous Knowledge Metabolism — Incremental Cycle

You are executing one cycle of the knowledge-metabolism loop. Follow the steps below strictly.

**Prerequisite:** `metabolism/config.json` must already exist with `currentDay >= 1`. If it is missing or `currentDay` is 0, ask the user to run `/metabolism-init` first.

## Preparation

1. Read `metabolism/config.json` for keywords, arXiv categories, `processed_ids`, and `currentDay`.
2. Read `metabolism/knowledge/_index.md` for the current knowledge state.

## Step 1: Search (incremental)

Run a sliding-window search (past 5 days), de-duplicating with `processed_ids`:

```
arxiv_search({
  query: "{keywords} AND cat:{category}",
  date_from: "{5 days ago YYYY-MM-DD}",
  sort_by: "submittedDate",
  max_results: 30
})

openalex_search({
  query: "{keywords}",
  filter: "from_publication_date:{5 days ago YYYY-MM-DD}",
  sort: "publication_date",
  max_results: 20
})
```

Merge results, de-duplicate by arXiv ID / DOI, and **skip any paper already in `processed_ids`**.

Download the new papers:

```
arxiv_download({ arxiv_ids: ["{id1}", "{id2}", ...] })
unpaywall_download({ dois: ["{doi1}", "{doi2}", ...] })
```

## Step 2: Read

For each new paper:

- Read the .tex source (preferred) or the PDF.
- Extract: core method, key conclusions, and how it relates to existing knowledge.

Append every paper's arXiv ID / DOI to `processed_ids` in `config.json`.

## Step 3: Update knowledge

Read the current `metabolism/knowledge/_index.md` and the relevant `topic-*.md`, then update them based on today's reading.

**Update principles:**

- New finding → add to the relevant section.
- Confirms an existing belief → add a supporting source.
- Contradicts an existing belief → flag the disagreement and keep both sides' evidence.
- Cross-topic link → record the connection.

**Length management:** keep each topic file under 200 lines. When approaching the limit, compress earlier content (merge similar conclusions, drop low-value entries) while preserving information density. Do not trade away key conclusions or source citations just to shrink the file.

## Step 4: Hypothesize

After updating knowledge, review what was added today and ask:

- Are there recurring patterns that have not been validated?
- Do two independent findings, when combined, suggest a new direction?
- Is there an obvious gap in existing methods?

**If you have an idea** → write to `metabolism/hypotheses/hyp-{NNN}.md`:

```markdown
# Hypothesis {NNN}

## Hypothesis
{One or two sentences stating a clear, falsifiable hypothesis in the language of the field.}

## Reasoning
{Which papers / knowledge support it? 2-3 paragraphs of reasoning.}

## Source papers
- {arxiv_id_1}: {title_1} (what inspired you)
- {arxiv_id_2}: {title_2} (what inspired you)

## Self-assessment
- Novelty: {1-5} - {reason}
- Feasibility: {1-5} - {reason}
- Impact: {1-5} - {reason}
```

Then notify the main session via `sessions_send`.

**Note:** in the message you send to the user, do not output a "trigger checklist". Just explain why the hypothesis is reasonable and which readings inspired it.

**If you have no idea** → skip; do not force one.

## Step 5: Log & Finish

Write `metabolism/log/{YYYY-MM-DD}.md`:

```markdown
# Day {currentDay} — {YYYY-MM-DD}

New papers: {N}
Knowledge updates: {brief summary of main changes}
Hypothesis: {yes (hyp-NNN) / none}
Anomalies: {download failures, API throttling, etc.; otherwise "none"}
```

Update `config.json`: increment `currentDay` by 1.

## Behaviour rules

1. Do not fabricate factual claims that are not in the papers, but you may use your own knowledge for reasoning and connection.
2. Do not generate a hypothesis when you do not have one.
3. Run autonomously; do not ask the human questions.
4. Always read the current contents of a knowledge file before modifying it.
