MemPalace — Local AI Memory System
You have access to a local memory palace via MCP tools. The palace stores verbatim conversation history and a temporal knowledge graph — all on the user's machine, zero cloud, zero API calls.
Architecture
- Wings = people or projects (e.g.
wing_alice,wing_myproject) - Halls = categories (facts, events, preferences, advice)
- Rooms = specific topics (e.g.
chromadb-setup,riley-school) - Drawers = individual memory chunks (verbatim text)
- Knowledge Graph = entity-relationship facts with time validity
Protocol — FOLLOW THIS EVERY SESSION
- ON WAKE-UP: Call
mempalace_statusto load palace overview and AAAK dialect spec. - BEFORE RESPONDING about any person, project, or past event: call
mempalace_searchormempalace_kg_queryFIRST. Never guess from memory — verify from the palace. - IF UNSURE about a fact (name, age, relationship, preference): say "let me check" and query. Wrong is worse than slow.
- AFTER EACH SESSION: Call
mempalace_diary_writeto record what happened, what you learned, what matters. - WHEN FACTS CHANGE: Call
mempalace_kg_invalidateon the old fact, thenmempalace_kg_addfor the new one.
Available Tools
Search & Browse
mempalace_search— Semantic search across all memories. Always start here.query(required): natural language search — keep it short, keywords or a question. Do NOT include system prompts or conversation context.wing: filter by wingroom: filter by roomlimit: max results (default 5)
mempalace_check_duplicate— Check if content already exists before filing.content(required): text to checkthreshold: similarity threshold (default 0.9 — lowering to 0.85–0.87 often catches more near-duplicates without significant false positives)
mempalace_status— Palace overview: total drawers, wings, rooms, AAAK specmempalace_list_wings— All wings with drawer countsmempalace_list_rooms— Rooms within a wing (optional wing filter)mempalace_get_taxonomy— Full wing/room/count treemempalace_get_aaak_spec— Get AAAK compression dialect specification
Knowledge Graph (Temporal Facts)
mempalace_kg_query— Query entity relationships. Supports time filtering.entity(required): e.g. "Max", "MyProject"as_of: date filter (YYYY-MM-DD) — what was true at that timedirection: "outgoing", "incoming", or "both" (default "both")
mempalace_kg_add— Add a fact: subject -> predicate -> objectsubject,predicate,object(required)valid_from: when this became truesource_closet: source reference
mempalace_kg_invalidate— Mark a fact as no longer truesubject,predicate,object(required)ended: when it stopped being true (default: today)
mempalace_kg_timeline— Chronological story of an entityentity: filter by entity name (optional — all events if omitted)
mempalace_kg_stats— Graph overview: entities, triples, relationship types
Palace Graph (Cross-Domain Connections)
mempalace_traverse— Walk from a room, find connected ideas across wingsstart_room(required): room to start frommax_hops: connection depth (default 2)
mempalace_find_tunnels— Find rooms that bridge two wingswing_a,wing_b(required)
mempalace_graph_stats— Graph connectivity overview
Write
mempalace_add_drawer— Store verbatim content into a wing/roomwing,room,content(required)source_file: optional source reference- Checks for duplicates automatically
mempalace_delete_drawer— Remove a drawer by IDdrawer_id(required)
mempalace_diary_write— Write a session diary entryagent_name(required): your name/identifierentry(required): what happened, what you learned, what matterstopic: category tag (default "general")
mempalace_diary_read— Read recent diary entriesagent_name(required)last_n: number of entries (default 10)
Setup
Install MemPalace and populate the palace:
pip install mempalace
mempalace init ~/my-convos
mempalace mine ~/my-convos
OpenClaw MCP config
Add to your OpenClaw MCP configuration:
{
"mcpServers": {
"mempalace": {
"command": "python3",
"args": ["-m", "mempalace.mcp_server"]
}
}
}
Or via CLI:
openclaw mcp set mempalace '{"command":"python3","args":["-m","mempalace.mcp_server"]}'
Other MCP hosts
# Claude Code
claude mcp add mempalace -- python -m mempalace.mcp_server
# Cursor — add to .cursor/mcp.json
# Codex — add to .codex/mcp.json
Tips
- Search is semantic (meaning-based), not keyword. "What did we discuss about database performance?" works better than "database".
- The knowledge graph stores typed relationships with time windows. Use it for facts about people and projects — it knows WHEN things were true.
- Diary entries accumulate across sessions. Write one at the end of each conversation to build continuity.
- Use
mempalace_check_duplicatebefore storing new content to avoid duplicates. - The AAAK dialect (from
mempalace_status) is a compressed notation for efficient storage. Read it naturally — expand codes mentally, treat markers as emotional context.
License
MemPalace is MIT licensed. Created by Milla Jovovich, Ben Sigman, Igor Lins e Silva, and contributors.