Persistent thought-graph memory for AI agents. Provides context generation, knowledge extraction, and autonomous think cycles.
Project description
Cashew 🥜
Persistent thought-graph memory for AI agents.
The name comes from asking "do cats eat cashews?" — a question I asked my aunt as a 10-year-old kid in India, because the cashews were left open in the kitchen and I knew stray cats sneak into homes to eat food. My family still brings it up every time I visit. I never stopped asking questions. This system doesn't either — autonomous think cycles find connections you didn't know existed.
📝 Blog post: I Built My AI a Brain and It Started Thinking for Itself
Architecture
What It Does
- Remembers across sessions. Decisions, patterns, relationships, and project context survive compaction and restart. Your agent picks up where it left off.
- Learns autonomously. Think cycles find cross-domain connections without prompting. A pattern in your work habits connects to a pattern in your communication style — the brain surfaces it.
- Stays fast at scale. sqlite-vec for O(log N) retrieval, recursive BFS graph walk, constant context cost regardless of graph size. 3,000 nodes costs the same as 300.
What If Forgetting Is the Intelligence?
Cashew doesn't hoard everything. Organic decay means low-value knowledge fades naturally while important patterns strengthen through use. No manual curation needed — the graph self-organizes through cross-linking and natural selection. See PHILOSOPHY.md for the full manifesto.
Quick Start
pip install cashew-brain
cashew init
cashew context --hints "test"
That's it. Your brain is empty but ready. Start extracting knowledge:
echo "I prefer TypeScript over JavaScript for complex projects" | cashew extract --input -
Query it back:
cashew context --hints "programming language preferences"
Integration
Claude Code
Copy the skill into your personal skills directory:
# From the cashew repo
cp -r skills/claude-code/ ~/.claude/skills/cashew/
This gives you the /cashew slash command and automatic context loading. Claude Code will query your brain before answering substantive questions and extract knowledge during conversations.
Or if you cloned the repo, just open it in Claude Code — the .claude/skills/cashew/ directory auto-discovers.
OpenClaw
Install as an OpenClaw skill for full automation — cron jobs handle extraction, think cycles, and dashboard deployment without manual intervention. See skills/openclaw/SKILL.md for setup instructions.
Ingest Sources
Cashew ships with built-in extractors for common knowledge sources. Each one handles checkpointing, incremental updates, and deduplication automatically.
Obsidian vault:
cashew ingest obsidian /path/to/vault
Parses YAML frontmatter (tags, aliases, dates), follows [[wikilinks]] to create edges between related notes, respects .obsidianignore, and auto-detects domains from your folder structure. Your second brain becomes your AI's brain.
OpenClaw session logs:
cashew ingest sessions /path/to/sessions/
Extracts knowledge from conversation history. Tracks how far into each session file it's read, so growing sessions get incrementally processed. Filters out tool calls and system messages.
Markdown directory:
cashew ingest markdown /path/to/notes/
General purpose extractor for any directory of .md files. Respects .cashewignore for excluding files.
Options:
cashew ingest --list # Show available extractors
cashew ingest obsidian /path --no-llm # Skip LLM, use paragraph splitting fallback
All extractors use LLM-based extraction by default for richer, typed knowledge (decisions, insights, facts). Use --no-llm for offline or token-free ingestion.
Python API
from core.context import ContextRetriever
from core.embeddings import load_embeddings
# Query context
embeddings = load_embeddings("path/to/graph.db")
retriever = ContextRetriever("path/to/graph.db", embeddings)
context = retriever.generate_context(hints=["work", "projects"])
Architecture
- Single SQLite file. No external servers, no separate indexes. Your entire brain is one portable file.
- Local embeddings. all-MiniLM-L6-v2 (384 dims). Downloads ~500MB on first run, then runs locally forever. No API calls for retrieval.
- LLM for intelligence. Extraction and think cycles need an LLM (Claude, GPT, etc). Retrieval and storage don't. Bring your own via
model_fnparameter or API key. - Retrieval. sqlite-vec seeds (O(log N) nearest neighbor) → recursive BFS graph walk (seeds=5, picks_per_hop=3, max_depth=3). The graph's organic connectivity provides implicit hierarchy — no synthetic summary nodes needed.
- Organic decay. Nodes that aren't accessed lose fitness over time. Low-fitness nodes get marked decayed and excluded from retrieval. The graph forgets what doesn't matter.
CLI Reference
| Command | Purpose |
|---|---|
cashew init |
Initialize a new brain |
cashew context --hints "..." |
Retrieve relevant context |
cashew extract --input file.md |
Extract knowledge from text |
cashew ingest obsidian /path |
Ingest an Obsidian vault |
cashew ingest sessions /path |
Ingest OpenClaw session logs |
cashew ingest markdown /path |
Ingest a directory of markdown files |
cashew think |
Run a think cycle |
cashew sleep |
Full sleep cycle (consolidation) |
cashew stats |
Graph statistics |
cashew dashboard |
Launch the live dashboard (graph + BFS search visualization) |
Dashboard
cashew dashboard --db data/graph.db --port 8765
# then open http://127.0.0.1:8765
A minimalist browser UI over the brain. The full graph renders as a canvas force layout colored by node type. The search box traces a live recursive-BFS walk: seeds arrive first, then each hop lights up in order with hop-colored edges and rings. Works on mobile (bottom sheet, drag-to-resize). Pass --host 0.0.0.0 to expose on the LAN. Auto-trigger a search via ?q=... in the URL.
Warm Daemon
Every CLI invocation normally loads the sentence-transformer model from scratch (~2s cold start). For a responsive query loop, run the warm daemon once and every call routes through it automatically — no code changes in consumers.
# Foreground (development)
cashew serve
# Persistent (macOS)
cp packaging/com.cashew.daemon.plist ~/Library/LaunchAgents/
# edit CASHEW_PATH in the plist to match your clone, then:
launchctl load ~/Library/LaunchAgents/com.cashew.daemon.plist
The daemon listens on ~/.cashew/daemon.sock. A content-hash embedding cache at ~/.cashew/embedding_cache.db makes repeat embeds free, keyed by (model_version, sha256(text)) — deterministic, so no invalidation logic is needed beyond model swaps.
Every entry point (context, extract, think, sleep cycles) checks the cache first, then the daemon, then falls back to in-process embedding if the daemon is down. Clients never need to know which path served them.
Requirements
- Python 3.10+
- ~2GB RAM (for embedding model)
- ~500MB disk (embedding model, downloaded on first use)
- An LLM API key for extraction and think cycles (optional for retrieval-only use)
Philosophy
Cashew ships with a philosophy document that defines how a brain-equipped agent should operate. It covers brain sovereignty, evidence over defaults, the sponge principle, cross-domain vision, and why divergence between instances is the whole point.
Read it: PHILOSOPHY.md
Development
git clone https://github.com/rajkripal/cashew.git
cd cashew
pip install -e ".[dev]"
pytest
See CLAUDE.md for the developer guide — architecture, schema, conventions, and engineering philosophy.
License
MIT — see LICENSE.
Built by rajkripal.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cashew_brain-1.0.0.tar.gz.
File metadata
- Download URL: cashew_brain-1.0.0.tar.gz
- Upload date:
- Size: 180.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2502e58155c29c01a7103eb4d4201bc373f2d780cbeb31423aa171f7a4a465c9
|
|
| MD5 |
2cddf819c361b9c16e17625c2eb15ca4
|
|
| BLAKE2b-256 |
186c52d2c3116d93272f979a1114e557b832a53036db0129df772afd3fc2c6c4
|
Provenance
The following attestation bundles were made for cashew_brain-1.0.0.tar.gz:
Publisher:
release.yml on rajkripal/cashew
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cashew_brain-1.0.0.tar.gz -
Subject digest:
2502e58155c29c01a7103eb4d4201bc373f2d780cbeb31423aa171f7a4a465c9 - Sigstore transparency entry: 1345250630
- Sigstore integration time:
-
Permalink:
rajkripal/cashew@d6330f6960c939ef3271ac04fc23a4768801b049 -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/rajkripal
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d6330f6960c939ef3271ac04fc23a4768801b049 -
Trigger Event:
release
-
Statement type:
File details
Details for the file cashew_brain-1.0.0-py3-none-any.whl.
File metadata
- Download URL: cashew_brain-1.0.0-py3-none-any.whl
- Upload date:
- Size: 137.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c218c86abb01697bcb176e799ed4cb497ffcb08685a020cc06c7de6012fc1903
|
|
| MD5 |
f53d4c93297ebfd0130c7631ba5fced3
|
|
| BLAKE2b-256 |
a4a7ef74406ac63e153040453e807410b52779c143ccf4beec35357c7e9e1277
|
Provenance
The following attestation bundles were made for cashew_brain-1.0.0-py3-none-any.whl:
Publisher:
release.yml on rajkripal/cashew
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
cashew_brain-1.0.0-py3-none-any.whl -
Subject digest:
c218c86abb01697bcb176e799ed4cb497ffcb08685a020cc06c7de6012fc1903 - Sigstore transparency entry: 1345250687
- Sigstore integration time:
-
Permalink:
rajkripal/cashew@d6330f6960c939ef3271ac04fc23a4768801b049 -
Branch / Tag:
refs/tags/v1.0.0 - Owner: https://github.com/rajkripal
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d6330f6960c939ef3271ac04fc23a4768801b049 -
Trigger Event:
release
-
Statement type: