Skip to content

Python API

High-level overview of the key Python interfaces you'd use to integrate MemPalace into your application.

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_drawers

For detailed parameter documentation, see API Reference.

Released under the MIT License.