Knowledge Agents
Knowledge agents let you compile a slice of your claude-mem observation history into a queryable “brain” that answers questions conversationally. Instead of getting raw search results back, you get synthesized, grounded answers drawn from your actual project history — decisions, discoveries, bugfixes, and features.Quick Start
Three ways to use knowledge agents, from simplest to most powerful.1. Create a Knowledge Agent
Use the/knowledge-agent skill or the MCP tools directly:
session_id is the agent — a Claude session with your history baked in.
2. Ask a Single Question
Once primed, ask any question and get a grounded answer:3. Start a Fresh Conversation
If the conversation drifts, or you want to ask an unrelated question against the same corpus, reprime to start clean:- The conversation went off-track and you want a clean slate
- You’re switching topics within the same corpus
- You want to ask a question without prior answers biasing the response
Keeping It Current
When new observations are added to your project, rebuild the corpus to pull in the latest, then reprime:The Workflow: Build, Prime, Query
1. Build a Corpus
A corpus is a filtered collection of observations saved as a JSON file. Use search filters to select exactly the slice of history you want.CorpusBuilder searches your observations, hydrates full records, parses structured fields (facts, concepts, files), calculates stats, and writes everything to ~/.claude-mem/corpora/hooks-expertise.corpus.json.
2. Prime the Knowledge Agent
Priming loads the entire corpus into a Claude session’s context window.session_id is the knowledge agent — a Claude session with your history baked in.
3. Query
Resume the primed session and ask questions.Filter Options
Use these parameters when building a corpus to control which observations are included:| Parameter | Type | Description |
|---|---|---|
name | string | Name for the corpus (used in all subsequent API calls) |
project | string | Filter by project name |
types | string[] | Filter by observation type (bugfix, feature, decision, discovery, refactor, change) |
concepts | string[] | Filter by tagged concepts |
files | string[] | Filter by files read or modified |
query | string | Full-text search query |
dateStart | string | Start date filter (YYYY-MM-DD) |
dateEnd | string | End date filter (YYYY-MM-DD) |
limit | number | Maximum observations to include |
Architecture
resume option lets you prime a session once (upload the corpus), save the session_id, and resume it for every future question. The corpus stays in context permanently — no re-uploading, no prompt caching tricks. The 1M token context window makes this viable: 2,000 observations at ~300 tokens each fits comfortably.
When to Use /knowledge-agent vs /mem-search
/mem-search | /knowledge-agent | |
|---|---|---|
| Returns | Raw observation records | Synthesized conversational answers |
| Best for | Finding specific observations, IDs, timelines | Asking questions about patterns, decisions, architecture |
| Token model | Pay-per-query (3-layer progressive disclosure) | Pay-once at prime time, then cheap follow-ups |
| Interaction | Search, filter, fetch | Ask questions in natural language |
| Data freshness | Always current (queries database live) | Snapshot at build time (rebuild to refresh) |
| Setup | None — works immediately | Build + prime required before first query |
/mem-search when you need to find something specific. Use /knowledge-agent when you want to understand something broadly.
API Reference
| Method | Path | Description |
|---|---|---|
| POST | /api/corpus | Build a new corpus from filters |
| GET | /api/corpus | List all corpora with stats |
| GET | /api/corpus/:name | Get corpus metadata |
| DELETE | /api/corpus/:name | Delete a corpus |
| POST | /api/corpus/:name/rebuild | Rebuild from stored filters |
| POST | /api/corpus/:name/prime | Create AI session with corpus loaded |
| POST | /api/corpus/:name/query | Ask the knowledge agent a question |
| POST | /api/corpus/:name/reprime | Fresh session (wipe prior Q&A) |
Edge Cases
- Session expiry: If
resumefails, the agent auto-reprimes from the corpus file and retries - SDK process exit: If the Claude process exits after yielding all messages, the agent treats it as success when the session_id or answer was already captured
- Empty corpus: A corpus with 0 observations is valid (just empty)
- Model from settings: Reads
CLAUDE_MEM_MODELfrom user settings — no hardcoded model IDs
Next Steps
- Memory Search - The 3-layer search workflow for finding specific observations
- Progressive Disclosure - Philosophy behind token-efficient retrieval
- Architecture Overview - System components

