Cut LLM agent token costs by 93%. Execution cache for LangChain, CrewAI, AutoGen, LangGraph — zero tokens on repeat runs, 2.66ms latency vs 20s.
Project description
Your agent runs the same task every week. It pays full LLM price every time. It never remembers. It never gets faster.
Mnemon fixes that. It caches what your agent has already figured out, learns from every run, and makes each subsequent run cheaper and faster than the last.
pip install mnemon-ai
mnemon demo # see it working in 30 seconds
What Mnemon does
Mnemon has three components. They work together automatically.
Mnemon uses two matching modes across both paths:
- System 1 — exact match. Sub-millisecond. Zero tokens. No LLM call.
- System 2 — semantic match. "Weekly security report" hits the cache for "generate security audit".
Both modes are active on both paths. MOTH uses them for response-level caching. The EME uses them for plan-level caching with gap fill on top.
1. Execution Memory Engine (EME) — the cache
The EME stores what your agent has done before. On repeat runs it skips the LLM entirely.
First run: 20,000ms · 1,250 tokens · full cost
Every repeat: 2.66ms · 0 tokens · $0.00
System 1 + System 2 matching, plus segment-level caching: only the parts of a plan that actually changed go to the LLM. Everything else comes from cache.
2. Experience Bus — the learning loop
The Bus watches every run in the background. You never call it directly — it's always on.
It detects patterns, flags failures, quarantines bad plans, and strengthens what works. The cache gets smarter every run, not just bigger.
You get this for free. Nothing to configure.
3. MOTH — the auto-instrumentation layer
MOTH patches your existing frameworks at startup. It's how Mnemon sees what your agent is doing without you changing any code.
Supported: Anthropic SDK · OpenAI SDK · LangChain · LangGraph · CrewAI · AutoGen
Which path should I use?
There are two ways to use Mnemon. Pick one based on what you're building.
Use Path 1 if you want caching with zero code changes. Drop it into any existing project — Anthropic, OpenAI, LangChain, CrewAI. Mnemon watches your LLM calls and caches the responses. Same input, instant response next time. Good for chatbots, simple agents, quick experiments. It does not track individual steps, quarantine bad plans, or learn which parts of a workflow are failing. If your input changes every run, it won't hit the cache.
Use Path 2 if you run structured recurring tasks — weekly reports, research pipelines, multi-step workflows. This gives you the full system: segment-level caching so only the parts that changed get regenerated, a learning loop that strengthens what works and quarantines what fails, and guided generation that tells your LLM exactly what to fill in. The more it runs, the smarter it gets.
It requires wrapping your generation logic in a function and calling m.run() — it's not zero code changes, but the payoff compounds with every run.
Path 1 — Response caching (zero code changes)
Use this if: you call an LLM directly and want to cache the responses. Works for chatbots, simple agents, any direct SDK usage.
import mnemon
mnemon.init() # patches your installed frameworks automatically
# your existing code — completely unchanged
from anthropic import Anthropic
client = Anthropic()
response = client.messages.create(
model="claude-sonnet-4-6",
max_tokens=1024,
messages=[{"role": "user", "content": "Generate weekly security report for Acme Corp"}]
)
First call: normal. Every call after with the same or similar input: instant, zero tokens.
What you get: System 1 + System 2 response caching. The Bus learning loop. All automatic.
Path 2 — Execution plan caching with m.run() (full system)
Use this if: your agent runs structured recurring tasks — research workflows, recurring reports, multi-step pipelines. This gives you the full EME with segment-level caching, gap fill, and guided generation.
import mnemon
from anthropic import Anthropic
client = Anthropic()
m = mnemon.init()
def generate_report(goal, inputs, context, capabilities, constraints):
# only called on a cache miss — put your real LLM logic here
response = client.messages.create(
model="claude-sonnet-4-6",
max_tokens=1024,
messages=[{"role": "user", "content": goal}],
)
return response.content[0].text
result = m.run(
goal="weekly security audit for Acme Corp",
inputs={"client": "Acme Corp", "week": "Apr 21-25"},
generation_fn=generate_report,
)
print(result["output"]) # your result
print(result["cache_level"]) # "system1" | "system2" | "miss"
print(result["tokens_saved"]) # tokens saved on this run
print(result["latency_saved_ms"]) # ms saved on this run
What you get: full EME — exact + semantic caching at the segment level, gap fill for partially changed plans, guided generation so your LLM only generates what's new, Bus learning loop, Retrospector quarantine.
Install
pip install mnemon-ai
System 2 semantic matching — enable one of:
pip install mnemon-ai[full] # offline, no API key (recommended)
export OPENAI_API_KEY=sk-... # or set this — auto-detected
Without either, Mnemon runs System 1 only (exact match). Still valuable, just no semantic matching.
Optional — share anonymous usage stats:
export MNEMON_TELEMETRY=1
The numbers
| System 1 hit latency | 2.66ms |
| Typical LLM call | ~20,000ms |
| Speedup on cache hit | 7,500× |
| Token reduction | 93% |
At scale (80% hit rate):
| Daily runs | Monthly savings |
|---|---|
| 100 | $56 |
| 1,000 | $503 |
| 10,000 | $5,034 |
Stanford researchers published Agentic Plan Caching at NeurIPS 2025, measuring 50.31% cost reduction with the same approach. Mnemon is the production implementation — one import, works today.
What prints on each run
First run:
Mnemon: first run — plan cached, next run will be instant
Cache hit:
Mnemon: cache hit · 1,250 tokens saved · ~$0.0038 · 20.0s faster
New input (cached for next time):
Mnemon: new input — cached, next run will be instant
Diagnostics
mnemon doctor # health check — DB, embedder, fragment library
mnemon demo # live demo — no API key needed
m = mnemon.get() # retrieve running instance from anywhere
print(m.get_stats()) # EME, bus, DB stats
print(m.waste_report) # repeated queries and their cost
Configuration
m = mnemon.init(tenant_id="acme_corp") # isolate by tenant
m = mnemon.init(silent=True) # suppress output
m = mnemon.init(eme_enabled=False) # bus + MOTH only
m = mnemon.init(bus_enabled=False) # EME + MOTH only
Multi-tenant — each tenant_id gets an isolated SQLite database:
from mnemon import Mnemon
async with Mnemon(tenant_id="acme_corp") as m:
result = await m.run(goal="...", inputs={...}, generation_fn=fn)
Fail-safe
Mnemon never crashes the system it wraps.
| What fails | What happens |
|---|---|
| EME cache | generation_fn called directly — no disruption |
| Experience Bus | agent continues unmonitored |
| Database | in-memory fallback |
vs. everything else
| Mnemon | Mem0 | LangMem | Roll your own | |
|---|---|---|---|---|
| Execution caching (skip LLM entirely) | ✅ | ❌ | ❌ | ❌ |
| System learning loop | ✅ | ❌ | ❌ | ❌ |
| Zero-code auto-instrumentation | ✅ | ❌ | ❌ | ❌ |
| Fully local (no cloud, no API) | ✅ | ❌ | ❌ | ✅ |
| One-line setup | ✅ | ❌ | ❌ | ❌ |
License
MIT. Free to use, free to build on.
Questions or integration help: mahikajadhav22@gmail.com
Your agents have a Mnemon now.
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 mnemon_ai-1.1.3.tar.gz.
File metadata
- Download URL: mnemon_ai-1.1.3.tar.gz
- Upload date:
- Size: 136.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e36785feb6214c5f98fd06eff557333f2d2bc7510e2df47c67d2eaa8e898f6f3
|
|
| MD5 |
464ce332c7aa0a18e097fc4e201304c2
|
|
| BLAKE2b-256 |
70fc4c986105746b9537574d1dfd92d12826ec3d04f73009a158351553b42e18
|
Provenance
The following attestation bundles were made for mnemon_ai-1.1.3.tar.gz:
Publisher:
publish.yml on smartass-4ever/Mnemon
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mnemon_ai-1.1.3.tar.gz -
Subject digest:
e36785feb6214c5f98fd06eff557333f2d2bc7510e2df47c67d2eaa8e898f6f3 - Sigstore transparency entry: 1629291834
- Sigstore integration time:
-
Permalink:
smartass-4ever/Mnemon@91be19f757220114791d17b387317ed6f576988c -
Branch / Tag:
refs/tags/v1.1.3 - Owner: https://github.com/smartass-4ever
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@91be19f757220114791d17b387317ed6f576988c -
Trigger Event:
release
-
Statement type:
File details
Details for the file mnemon_ai-1.1.3-py3-none-any.whl.
File metadata
- Download URL: mnemon_ai-1.1.3-py3-none-any.whl
- Upload date:
- Size: 150.6 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 |
db2b1f71fb867c780757b4768280b8a9cee862eb2ad4809c260ffdb40a6a696d
|
|
| MD5 |
54c219f6be6ded821ba312c9960ab4ad
|
|
| BLAKE2b-256 |
3096c8650fd313f61d538ac47da766d8c691c02c37626cd699ff409123502891
|
Provenance
The following attestation bundles were made for mnemon_ai-1.1.3-py3-none-any.whl:
Publisher:
publish.yml on smartass-4ever/Mnemon
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mnemon_ai-1.1.3-py3-none-any.whl -
Subject digest:
db2b1f71fb867c780757b4768280b8a9cee862eb2ad4809c260ffdb40a6a696d - Sigstore transparency entry: 1629291870
- Sigstore integration time:
-
Permalink:
smartass-4ever/Mnemon@91be19f757220114791d17b387317ed6f576988c -
Branch / Tag:
refs/tags/v1.1.3 - Owner: https://github.com/smartass-4ever
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@91be19f757220114791d17b387317ed6f576988c -
Trigger Event:
release
-
Statement type: