Python API
High-level overview of the key Python interfaces you'd use to integrate MemPalace into your application.
Search
The primary way to query the palace programmatically.
python
from mempalace.searcher import search_memories
results = search_memories(
query="why did we switch to GraphQL",
wing="myapp", # optional filter
room="architecture", # optional filter
n_results=5,
)
# Results structure:
# {
# "query": "...",
# "filters": {"wing": "myapp", "room": "architecture"},
# "results": [
# {"text": "...", "wing": "...", "room": "...", "source_file": "...", "similarity": 0.89}
# ]
# }Memory Stack
The 4-layer memory system with a unified interface.
python
from mempalace.layers import MemoryStack
stack = MemoryStack() # uses default paths from MempalaceConfig
# Wake-up: L0 (identity) + L1 (essential story)
context = stack.wake_up(wing="myapp") # ~170-900 tokens
# On-demand: L2 retrieval
recall = stack.recall(wing="myapp", room="auth", n_results=10)
# Deep search: L3 semantic search
results = stack.search("pricing change", wing="myapp")
# Status
status = stack.status()Knowledge Graph
Temporal entity-relationship graph built on SQLite.
python
from mempalace.knowledge_graph import KnowledgeGraph
kg = KnowledgeGraph() # uses default path: ~/.mempalace/knowledge_graph.sqlite3
# Write
kg.add_entity("Kai", entity_type="person")
kg.add_triple("Kai", "works_on", "Orion", valid_from="2025-06-01")
kg.invalidate("Kai", "works_on", "Orion", ended="2026-03-01")
# Read
facts = kg.query_entity("Kai", as_of="2026-01-15", direction="both")
relationships = kg.query_relationship("works_on")
timeline = kg.timeline("Orion")
stats = kg.stats()Palace Graph
Room-based navigation graph built from ChromaDB metadata.
python
from mempalace.palace_graph import build_graph, traverse, find_tunnels, graph_stats
# Build the graph
nodes, edges = build_graph()
# Navigate
path = traverse("auth-migration", max_hops=2)
tunnels = find_tunnels(wing_a="wing_code", wing_b="wing_team")
stats = graph_stats()AAAK Dialect
Lossy compression for token density at scale.
python
from mempalace.dialect import Dialect
# Basic
dialect = Dialect()
text = "We decided to use GraphQL because REST was too chatty for our dashboard."
compressed = dialect.compress(text)
# With entity mappings
dialect = Dialect(entities={"Alice": "ALC", "Bob": "BOB"})
compressed = dialect.compress(text, metadata={"wing": "myapp"})
# From config
dialect = Dialect.from_config("entities.json")
# Stats
stats = dialect.compression_stats(text, compressed)Configuration
python
from mempalace.config import MempalaceConfig
config = MempalaceConfig()
print(config.palace_path) # ~/.mempalace/palace
print(config.collection_name) # mempalace_drawersFor detailed parameter documentation, see API Reference.
