MCP Hub
Back to servers

subcog

Subcog is a persistent memory system for AI coding assistants that captures decisions and context using hybrid semantic search and Git-based persistence.

Stars
3
Tools
23
Updated
Jan 18, 2026
Validated
Feb 5, 2026

Subcog

CI Rust Version License Clippy cargo-deny

A persistent memory system for AI coding assistants. Subcog captures decisions, learnings, and context from coding sessions and surfaces them when relevant.

Subcog Prompt Library Workflow

Overview

Subcog delivers:

  • Single-binary distribution (<100MB, <10ms cold start)
  • Pluggable storage backends (SQLite+usearch, PostgreSQL+pgvector, Filesystem)
  • MCP server integration for AI agent interoperability
  • Claude Code hooks for seamless IDE integration
  • Semantic search with hybrid vector + BM25 ranking
  • Faceted storage with project, branch, and file path filtering
  • Branch garbage collection for stale branch cleanup

ADR Compliance

ADR compliance is tracked in docs/adrs/README.md. Current compliance is 95% (55/58 active ADRs) with documented partials in ADR-0003 and ADR-0039.

Benchmark Results

Subcog achieves 97% accuracy on factual recall (LongMemEval) and 57% on personal context (LoCoMo), compared to 0% baseline without memory. See full benchmark results.

BenchmarkWith SubcogBaselineImprovement
LongMemEval97%0%+97%
LoCoMo57%0%+57%
ContextBench24%0%+24%
MemoryAgentBench28%21%+7%

Features

Core (Always Available)

  • Memory capture with automatic embedding generation (384-dimensional vectors)
  • Real semantic search using all-MiniLM-L6-v2 via fastembed-rs
  • Hybrid search combining BM25 text search + vector similarity (RRF fusion)
  • Normalized scores (0.0-1.0 range) for intuitive relevance understanding
  • SQLite persistence as single source of truth (ACID-compliant)
  • Faceted storage with project_id, branch, and file_path fields
  • Multi-domain memories (project, user, organization)
  • 10 memory namespaces (decisions, learnings, patterns, blockers, etc.)
  • Branch garbage collection for tombstoning stale branch memories
  • Migration tools for upgrading existing memories to use embeddings

Enhanced (Opt-in)

  • Entity and temporal extraction
  • Secrets filtering (API keys, PII detection)
  • OpenTelemetry observability
  • Full Claude Code hook integration

LLM-Powered (Requires Provider)

  • Implicit capture from conversations
  • Memory consolidation and summarization
  • Supersession detection
  • Temporal reasoning queries

Installation

Multiple installation methods are available. See INSTALLATION.md for detailed instructions.

# npm/npx (recommended for quick start)
npx @zircote/subcog --help
npm install -g @zircote/subcog

# Homebrew (macOS/Linux)
brew install zircote/tap/subcog

# Cargo (Rust developers)
cargo install subcog

# Docker
docker run --rm ghcr.io/zircote/subcog --help

# Binary download
curl -LO https://github.com/zircote/subcog/releases/latest/download/subcog-VERSION-TARGET.tar.gz
MethodPlatformsAuto-update
npm/npxmacOS, Linux, WindowsVia npm
HomebrewmacOS, Linuxbrew upgrade
CargoAllcargo install
Dockerlinux/amd64, linux/arm64Pull latest tag
BinaryAllManual

Quick Start

# Capture a memory
subcog capture --namespace decisions "Use PostgreSQL for primary storage due to ACID requirements"

# Search memories (semantic search with normalized scores 0.0-1.0)
subcog recall "database storage decision"

# Search with raw RRF scores (for debugging)
subcog recall "database storage decision" --raw

# Check status
subcog status

# Sync with git remote
subcog sync

# Migrate existing memories to use real embeddings
subcog migrate embeddings

Score Normalization

Search results return normalized scores in the 0.0-1.0 range:

  • 1.0: Best match in the result set
  • >=0.7: Strong semantic match
  • >=0.5: Moderate relevance
  • <0.5: Weak match

Use --raw flag to see the underlying RRF (Reciprocal Rank Fusion) scores.

MCP Server

Run as an MCP server for AI agent integration:

subcog serve

Configure in Claude Desktop's claude_desktop_config.json:

{
  "mcpServers": {
    "subcog": {
      "command": "subcog",
      "args": ["serve"]
    }
  }
}

Available MCP Tools

Subcog exposes ~22 consolidated MCP tools (see ADR-0061 for the consolidation design):

CategoryToolsDescription
Coresubcog_capture, subcog_recall, subcog_statusMemory CRUD and search
Lifecyclesubcog_sync, subcog_consolidate, subcog_reindexMaintenance operations
CRUDsubcog_get, subcog_update, subcog_delete, subcog_listIndividual memory operations
Bulksubcog_delete_all, subcog_restore, subcog_historyBulk and recovery operations
Graphsubcog_graph, subcog_entities, subcog_relationshipsKnowledge graph queries
Promptssubcog_prompts, prompt_understandingPrompt template management
Templatessubcog_templatesContext template management
Sessionsubcog_init, subcog_get_summary, subcog_namespacesSession and namespace info
Compliancesubcog_gdpr_exportData export for compliance

When working with an agent, treat inputs that match MCP tool names as tool invocations (not shell commands) unless you explicitly say "shell" or "run in terminal".

Transport Security

Subcog supports two transport modes with different security models:

Stdio Transport (Default)

The stdio transport is the default and recommended mode for local development:

PropertyDescription
Trust ModelProcess isolation via OS - parent spawns subcog as child process
Network ExposureNone - communication only via stdin/stdout pipes
AuthenticationImplicit - same-user execution, no credentials required
ConfidentialityData never leaves local machine unless explicitly synced
IntegrityOS guarantees pipe integrity, no MITM attacks possible

When to use: Local development with Claude Desktop or other MCP clients that spawn subcog directly.

HTTP Transport (Optional)

Enable the HTTP transport for network-accessible deployments:

# Enable HTTP transport
subcog serve --http --port 8080

# With JWT authentication (recommended for production)
subcog serve --http --port 8080 --jwt-secret "your-secret-key"
PropertyDescription
Trust ModelJWT token authentication required
Network ExposureBinds to specified port (localhost by default)
AuthenticationJWT tokens with configurable expiry
CORSConfigurable allowed origins
TLSUse a reverse proxy (nginx, Caddy) for HTTPS

When to use: Team environments, remote access, or integration with web-based clients.

Data Protection

Both transports include built-in security features:

  • Secrets Detection: API keys, tokens, and passwords are detected and optionally redacted
  • PII Filtering: Personal information can be masked before storage
  • Encryption at Rest: Enable with encryption_enabled = true (default: true)
  • Audit Logging: All operations are logged for compliance (SOC2, GDPR)

See environment-variables.md for security configuration options.

Claude Code Hooks

Subcog integrates with all 5 Claude Code hooks:

HookPurpose
SessionStartInject relevant context at session start
UserPromptSubmitDetect capture signals in prompts
PostToolUseSurface related memories after file operations
PreCompactAnalyze conversation for auto-capture
StopFinalize session, sync to remote

Configure in ~/.claude/settings.json:

{
  "hooks": {
    "SessionStart": [{ "command": "subcog hook session-start" }],
    "UserPromptSubmit": [{ "command": "subcog hook user-prompt-submit" }],
    "PostToolUse": [{ "command": "subcog hook post-tool-use" }],
    "PreCompact": [{ "command": "subcog hook pre-compact" }],
    "Stop": [{ "command": "subcog hook stop" }]
  }
}

Migration

Upgrade existing memories to use real embeddings:

# Dry-run (see what would be migrated)
subcog migrate embeddings --dry-run

# Migrate all memories without embeddings
subcog migrate embeddings

# Force re-generation of all embeddings
subcog migrate embeddings --force

# Migrate from a specific repository
subcog migrate embeddings --repo /path/to/repo

The migration command:

  • Scans all memories in the index
  • Generates embeddings using fastembed (all-MiniLM-L6-v2)
  • Stores embeddings in the vector backend (usearch HNSW)
  • Skips memories that already have embeddings (unless --force)
  • Shows progress with migrated/skipped/error counts

Architecture

Subcog uses a three-layer storage architecture to separate concerns:

System Architecture Diagram

flowchart TB
    subgraph Access["Access Layer"]
        CLI["CLI<br/>subcog capture/recall/sync"]
        MCP["MCP Server<br/>JSON-RPC over stdio"]
        Hooks["Claude Code Hooks<br/>SessionStart, UserPrompt, Stop"]
    end

    subgraph Services["Service Layer"]
        Capture["CaptureService<br/>Memory ingestion"]
        Recall["RecallService<br/>Hybrid search"]
        Sync["SyncService<br/>Git remote sync"]
        GC["GCService<br/>Branch cleanup"]
        Dedup["DeduplicationService<br/>3-tier duplicate detection"]
        Context["ContextBuilder<br/>Adaptive injection"]
    end

    subgraph Storage["Three-Layer Storage"]
        subgraph Persistence["Persistence Layer<br/>(Authoritative)"]
            SQLiteP["SQLite<br/>(default)"]
            PostgresP["PostgreSQL"]
            FS["Filesystem"]
        end

        subgraph Index["Index Layer<br/>(Searchable)"]
            SQLiteI["SQLite + FTS5<br/>(default)"]
            PostgresI["PostgreSQL FTS"]
            Redis["RediSearch"]
        end

        subgraph Vector["Vector Layer<br/>(Embeddings)"]
            usearch["usearch HNSW<br/>(default)"]
            pgvector["pgvector"]
            RedisV["Redis Vector"]
        end
    end

    subgraph External["External Systems"]
        FastEmbed["FastEmbed<br/>all-MiniLM-L6-v2"]
        LLM["LLM Provider<br/>Anthropic/OpenAI/Ollama"]
        Git["Git Remote<br/>notes/subcog/*"]
    end

    CLI --> Capture
    CLI --> Recall
    CLI --> Sync
    MCP --> Capture
    MCP --> Recall
    Hooks --> Context
    Hooks --> Capture

    Capture --> Persistence
    Capture --> Index
    Capture --> Vector
    Capture --> FastEmbed
    Capture --> Dedup

    Recall --> Index
    Recall --> Vector
    Recall --> FastEmbed

    Sync --> Git

    Context --> Recall
    Context --> LLM

    Dedup --> Recall
    Dedup --> FastEmbed

    GC --> Persistence
    GC --> Index

    style Access fill:#e1f5fe
    style Services fill:#fff3e0
    style Storage fill:#e8f5e9
    style External fill:#fce4ec

Data Flow Diagram

sequenceDiagram
    participant User
    participant CLI/MCP
    participant CaptureService
    participant Dedup
    participant FastEmbed
    participant Persistence
    participant Index
    participant Vector

    User->>CLI/MCP: subcog capture "decision..."
    CLI/MCP->>CaptureService: CaptureRequest
    CaptureService->>Dedup: Check duplicate
    Dedup->>Index: Hash tag lookup (exact)
    Dedup->>FastEmbed: Generate embedding
    Dedup->>Vector: Similarity search (semantic)
    Dedup-->>CaptureService: Not duplicate

    CaptureService->>FastEmbed: Generate embedding
    FastEmbed-->>CaptureService: [384-dim vector]

    par Store in all layers
        CaptureService->>Persistence: Store memory
        CaptureService->>Index: Index for FTS
        CaptureService->>Vector: Store embedding
    end

    CaptureService-->>CLI/MCP: CaptureResult{id, urn}
    CLI/MCP-->>User: Memory captured

Hybrid Search Flow

flowchart LR
    Query["Query: 'database storage decision'"]

    subgraph Search["Parallel Search"]
        BM25["BM25 Search<br/>(Index Layer)"]
        VectorSearch["Vector Search<br/>(Vector Layer)"]
    end

    subgraph Results["Raw Results"]
        BM25Results["id1: 2.3<br/>id2: 1.8<br/>id3: 1.2"]
        VectorResults["id2: 0.92<br/>id1: 0.85<br/>id4: 0.78"]
    end

    RRF["RRF Fusion<br/>score = sum(1/(k+rank))"]

    Final["Final Results<br/>(normalized 0.0-1.0)<br/>id2: 1.00<br/>id1: 0.87<br/>id3: 0.45<br/>id4: 0.38"]

    Query --> BM25
    Query --> VectorSearch
    BM25 --> BM25Results
    VectorSearch --> VectorResults
    BM25Results --> RRF
    VectorResults --> RRF
    RRF --> Final

ASCII Architecture Reference

                              +-----------------+
                              |   Access Layer  |
                              +-----------------+
                              |  CLI | MCP | Hooks
                              +--------+--------+
                                       |
                              +--------v--------+
                              |  Service Layer  |
                              +-----------------+
                              | Capture | Recall | Sync | GC
                              +--------+--------+
                                       |
        +------------------------------+------------------------------+
        |                              |                              |
+-------v-------+             +--------v-------+             +--------v-------+
|  Persistence  |             |     Index      |             |     Vector     |
|    Layer      |             |     Layer      |             |     Layer      |
+---------------+             +----------------+             +----------------+
|               |             |                |             |                |
| - Authoritative             | - Full-text    |             | - Embeddings   |
|   source of truth           |   search (BM25)|             |   (384-dim)    |
| - ACID storage              | - Faceted      |             | - Similarity   |
| - Durable                   |   filtering    |             |   search (ANN) |
|               |             |                |             |                |
+-------+-------+             +--------+-------+             +--------+-------+
        |                              |                              |
+-------v-------+             +--------v-------+             +--------v-------+
|    SQLite     |             | SQLite + FTS5  |             |    usearch     |
|  (default)    |             |   (default)    |             |   (HNSW)       |
+---------------+             +----------------+             +----------------+
|  PostgreSQL   |             |  PostgreSQL    |             |   pgvector     |
+---------------+             +----------------+             +----------------+
|  Filesystem   |             |  RediSearch    |             | Redis Vector   |
+---------------+             +----------------+             +----------------+

Layer Responsibilities

LayerPurposeDefault BackendAlternatives
PersistenceAuthoritative storage, ACID guaranteesSQLitePostgreSQL, Filesystem
IndexFull-text search, BM25 rankingSQLite + FTS5PostgreSQL, RediSearch
VectorEmbedding storage, ANN searchusearch (HNSW)pgvector, Redis Vector

For detailed architecture documentation, see src/storage/traits/mod.rs.

Development

Prerequisites

  • Rust 1.88+ (Edition 2024)
  • Git 2.30+
  • cargo-deny for supply chain security

Setup

git clone https://github.com/zircote/subcog.git
cd subcog

# Build
cargo build

# Run tests
cargo test

# Run all checks
cargo fmt -- --check && \
cargo clippy --all-targets --all-features -- -D warnings && \
cargo test && \
cargo doc --no-deps && \
cargo deny check

Project Structure

src/
├── lib.rs              # Library entry point
├── main.rs             # CLI entry point
├── models/             # Data structures (Memory, Domain, Namespace)
├── storage/            # Storage backends (SQLite, PostgreSQL, usearch)
│   └── traits/         # Backend trait definitions (see mod.rs for docs)
├── services/           # Business logic (Capture, Recall, Sync)
├── mcp/                # MCP server implementation
├── hooks/              # Claude Code hook handlers
├── embedding/          # Vector embedding generation
└── observability/      # Tracing, metrics, logging

docs/
├── QUICKSTART.md       # Getting started guide
├── TROUBLESHOOTING.md  # Common issues and solutions
├── PERFORMANCE.md      # Performance tuning guide
├── research/           # Research documents
└── spec/               # Specification documents

Configuration

Configuration file at ~/.config/subcog/config.toml:

[storage]
backend = "sqlite"  # "sqlite", "postgres", "filesystem"
data_dir = "~/.local/share/subcog"

[embedding]
model = "all-MiniLM-L6-v2"
dimensions = 384

[hooks]
enabled = true
session_start_timeout_ms = 2000
user_prompt_timeout_ms = 50

[llm]
provider = "anthropic"  # Optional: for Tier 3 features

Faceted Capture

Memories can be tagged with project, branch, and file path:

# Capture with facets (auto-detected from git context)
subcog capture --namespace decisions "Use PostgreSQL"

# Capture with explicit facets
subcog capture --namespace decisions --project my-project --branch feature/auth "Added JWT support"

# Search within a project
subcog recall "authentication" --project my-project

# Search within a branch
subcog recall "bug fix" --branch feature/auth

# Include tombstoned memories
subcog recall "old decision" --include-tombstoned

Branch Garbage Collection

Clean up memories from deleted branches:

# GC current project (dry-run)
subcog gc --dry-run

# GC specific branch
subcog gc --branch feature/old-branch

# Purge tombstoned memories older than 30 days
subcog gc --purge --older-than 30d

Performance Targets

MetricTargetActual
Cold start<10ms~5ms
Capture latency<30ms~25ms
Search latency (100 memories)<20ms~82us
Search latency (1,000 memories)<50ms~413us
Search latency (10,000 memories)<100ms~3.7ms
Binary size<100MB~50MB
Memory (idle)<50MB~30MB

All performance targets are exceeded by 10-100x. Benchmarks run via cargo bench.

For performance tuning, see docs/PERFORMANCE.md.

Documentation

DocumentDescription
INSTALLATION.mdComplete installation guide (npm, Docker, Homebrew, Cargo)
QUICKSTART.mdGetting started guide
TROUBLESHOOTING.mdCommon issues and solutions
PERFORMANCE.mdPerformance tuning guide
environment-variables.mdEnvironment variable reference
URN-GUIDE.mdMemory URN scheme documentation

Specification

Active Work

See docs/spec/active/ for current work in progress.

Completed Specifications

Full specification documents for the storage architecture are in docs/spec/completed/2026-01-03-storage-simplification/:

License

This project is licensed under the MIT License - see the LICENSE file for details.

Acknowledgments

  • fastembed - Embedding generation
  • usearch - Vector similarity search
  • rmcp - MCP protocol implementation

Reviews

No reviews yet

Sign in to write a review