Open-source memory framework for AI agents
Project description
Astrocyte
Open-source memory framework for AI agents. Retain, recall, and synthesize — with pluggable backends, built-in governance, and 18 framework integrations.
What is Astrocyte?
Astrocyte gives AI agents persistent memory — store what matters, retrieve what's relevant, synthesize answers from accumulated knowledge. It sits between your agents and their storage, providing:
- Three operations:
retain(),recall(),reflect()— one API for every agent and every backend - Pluggable backends: Tier 1 storage (pgvector, Pinecone, Qdrant, Neo4j) or Tier 2 engines (Mystique, Mem0, Zep, Letta)
- Built-in governance: PII scanning, rate limits, token budgets, circuit breakers, access control, observability
- 18 framework integrations: LangGraph, CrewAI, OpenAI, Claude Agent SDK, Google ADK, AutoGen, and more
- MCP server: Any MCP-capable agent (Claude Code, Cursor, Windsurf) gets memory with zero code
Quick start
pip install astrocyte
from astrocyte import Astrocyte
brain = Astrocyte.from_config("astrocyte.yaml")
# Store a memory
await brain.retain("Calvin prefers dark mode", bank_id="user-123")
# Recall relevant memories
hits = await brain.recall("What are Calvin's preferences?", bank_id="user-123")
# Synthesize an answer from memory
result = await brain.reflect("Summarize what we know about Calvin", bank_id="user-123")
Agent framework integrations
Astrocyte works with every major agent framework through thin middleware — one integration per framework, works with every memory backend.
| Framework | Module |
|---|---|
| LangGraph / LangChain | astrocyte.integrations.langgraph |
| CrewAI | astrocyte.integrations.crewai |
| OpenAI Agents SDK | astrocyte.integrations.openai_agents |
| Claude Agent SDK | astrocyte.integrations.claude_agent_sdk |
| Google ADK | astrocyte.integrations.google_adk |
| Pydantic AI | astrocyte.integrations.pydantic_ai |
| AutoGen / AG2 | astrocyte.integrations.autogen |
| Smolagents (HuggingFace) | astrocyte.integrations.smolagents |
| LlamaIndex | astrocyte.integrations.llamaindex |
| Semantic Kernel | astrocyte.integrations.semantic_kernel |
| DSPy | astrocyte.integrations.dspy |
| CAMEL-AI | astrocyte.integrations.camel_ai |
| BeeAI (IBM) | astrocyte.integrations.beeai |
| Strands Agents (AWS) | astrocyte.integrations.strands |
| LiveKit Agents | astrocyte.integrations.livekit |
| Haystack (deepset) | astrocyte.integrations.haystack |
| Microsoft Agent Framework | astrocyte.integrations.microsoft_agent |
| MCP (Claude Code, Cursor) | astrocyte.mcp |
MCP server
Any MCP-capable agent gets memory with zero code integration:
{
"mcpServers": {
"memory": {
"command": "astrocyte-mcp",
"args": ["--config", "astrocyte.yaml"]
}
}
}
Built-in governance
Neuroscience-inspired policies that protect every operation — regardless of backend:
- PII barriers — regex, NER, or LLM-based scanning with redact/reject/warn actions
- Rate limits & quotas — token bucket rate limiting and daily quotas per bank
- Circuit breakers — automatic degraded mode when backends go down
- Access control — per-bank read/write/forget/admin permissions
- Observability — OpenTelemetry spans and Prometheus metrics on every operation
- Data governance — classification levels, compliance profiles (GDPR, HIPAA, PDPA)
Multi-bank orchestration
Query across personal, team, and org banks with cascade, parallel, or first-match strategies:
hits = await brain.recall(
"What are Calvin's preferences and team policies?",
banks=["personal", "team", "org"],
strategy="cascade",
)
Memory portability
Export and import memories between providers — no vendor lock-in:
await brain.export_bank("user-123", "./backup.ama.jsonl")
await brain.import_bank("user-123", "./backup.ama.jsonl")
Evaluation
Benchmark memory quality with built-in suites and DeepEval LLM-as-judge:
from astrocyte.eval import MemoryEvaluator
evaluator = MemoryEvaluator(brain)
results = await evaluator.run_suite("basic", bank_id="eval-bank")
print(f"Recall precision: {results.metrics.recall_precision:.2%}")
Benchmarks
Astrocyte includes adapters for two academic memory benchmarks plus built-in eval suites.
| Benchmark | What it tests | Dataset |
|---|---|---|
| LoCoMo (ECAI 2025) | Long-term conversational memory — single-hop, multi-hop, temporal, open-domain QA | snap-research/locomo |
| LongMemEval | Long-context memory extraction, reasoning, temporal ordering | xiaowu0162/LongMemEval |
| Built-in suites | basic (quick validation) and accuracy (retrieval quality with ground truth) |
Included |
Quick start
# Smoke test — no API key needed, in-memory providers
make bench-smoke
# With real LLM providers (requires OPENAI_API_KEY)
export OPENAI_API_KEY=sk-...
# Datasets are fetched automatically on first run
make bench-locomo-quick # LoCoMo, 50 questions (~2-3 min)
make bench-locomo # LoCoMo, full dataset (~30-60 min)
make bench-longmemeval # LongMemEval
make bench-builtin # Built-in suites only
make bench # All benchmarks
LLM adapter comparison
Compare the built-in OpenAI provider against the LiteLLM adapter (same models, isolates the adapter as the variable):
pip install astrocyte-llm-litellm # or: uv pip install -e ../adapters-llm-py/astrocyte-llm-litellm
make bench-compare # Runs 50 LoCoMo questions through each
Results are written to benchmark-results/openai/latest.json and benchmark-results/litellm/latest.json.
Dataset management
Datasets are cloned to datasets/ (gitignored) on first benchmark run. To manage manually:
make fetch-datasets # Fetch all datasets
make clean-datasets # Remove downloaded datasets
make clean-results # Remove benchmark results
See docs/_design/evaluation.md for the full evaluation specification.
Development
From astrocyte-py/ with the dev extra:
uv sync --extra dev
uv run ruff check astrocyte/ tests/
uv run python -m pytest tests/ -x --tb=short
Git hooks (Ruff via pre-commit) — reduces CI lint failures. From the repository root (parent of astrocyte-py/):
uv sync --extra dev --directory astrocyte-py
uv run --project astrocyte-py pre-commit install
Hooks run automatically on git commit; run on all files anytime with:
uv run --project astrocyte-py pre-commit run --all-files
CodeQL is not run in pre-commit (too slow for every commit). Enable Code scanning under the repo’s Settings → Code security so GitHub runs CodeQL on pushes/PRs using the default or advanced setup.
Documentation
astrocyteai.github.io/astrocyte
- Quick Start
- Architecture
- Provider SPI
- Integration guides (one per framework)
License
Apache 2.0 — see LICENSE.
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 astrocyte-0.8.1.tar.gz.
File metadata
- Download URL: astrocyte-0.8.1.tar.gz
- Upload date:
- Size: 455.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2cb0249b31987ed0248ab61734d85d452e85b1b0195058eff32fc05b1b513c2d
|
|
| MD5 |
2c66f44f4a7e18f99e2c2a7652811e19
|
|
| BLAKE2b-256 |
243ba22017f1cec1edf8ffa83a27dad90fbc29e6c55c57fb8e5d666d96951345
|
File details
Details for the file astrocyte-0.8.1-py3-none-any.whl.
File metadata
- Download URL: astrocyte-0.8.1-py3-none-any.whl
- Upload date:
- Size: 217.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d31a36b9e2f58ccd0b1b4c3874f3c2f4e42ec5ec005083c5760145e6b8ac89c8
|
|
| MD5 |
cd2bb3f7092d6af179f52d142f12e9d6
|
|
| BLAKE2b-256 |
fe5746e056ff8450cee388b3c67261d327e5384847df97f295ce637ca7800541
|