Closed-loop reflection / skill creation agent on LangGraph + deepagents. Faithful reproduction of Nous Research's Hermes Agent.
Reason this release was yanked:
Wheel shipped without required files — agent crashes on import. Upgrade to v0.1.3.
Project description
deepagent-hermes
A faithful reproduction of Nous Research's Hermes Agent on top of LangGraph + deepagents + langgraph-stream-parser.
Status: v0.1.0 live on PyPI. Spec at SPEC.md. Release notes in CHANGELOG.md. The runtime is verified end-to-end against a real Anthropic model — both the memory loop and the skill-creation loop close autonomously; see examples/dogfood.py and examples/dogfood_procedural.py for the traces.
What it is
A deepagents-built agent with a closed reflection→skill-creation loop:
- After ~10 tool-using iterations, a review subagent runs in the background, writes/patches a
SKILL.mdcapturing the pattern it just exercised, and ships it to a skill library. - Next session, the agent reads the library at startup, sees the new skill's description in its system prompt, and can
skill_view(name)to load the full body on demand (progressive disclosure per the agentskills.io spec). - A weekly curator consolidates skills into umbrellas and archives stale ones.
- A frozen-snapshot memory (
MEMORY.md+USER.md) preserves prefix-cache hits for the entire session. - FTS5 session search indexes every past conversation in a local SQLite DB.
- Bundled MarkdownProvider that keyword-searches
<HERMES_HOME>/memories/notes/*.md— drop hand-authored long-form context there and the agent surfaces relevant sections on demand. Zero external dependencies.
Designed to be loaded into the existing deepagent-* host family (deepagent-code, deepagent-lab, cowork-dash, deepagent-vscode) without UI changes — set DEEPAGENT_AGENT_SPEC=deepagent_hermes.agent:graph in any of them.
Installation
pip install deepagent-hermes
Or with uv (recommended):
uv venv .venv
. .venv/Scripts/activate # Windows
. .venv/bin/activate # macOS / Linux
uv pip install deepagent-hermes
Optional extras
pip install "deepagent-hermes[daytona]" # Daytona sandbox terminal backend
pip install "deepagent-hermes[modal]" # Modal sandbox terminal backend
pip install "deepagent-hermes[ssh]" # paramiko-backed SSH terminal backend
pip install "deepagent-hermes[dev]" # tests + lint (contributors only)
ANTHROPIC_API_KEY is required for the default model (anthropic:claude-sonnet-4-5-20250929). Swap the model via --model on the CLI or model.default in deepagent-hermes.toml — any init_chat_model string works.
Quick start
# show resolved config + sources
deepagent-hermes --show-config
# interactive chat
deepagent-hermes chat
# from inside chat:
# /skills list available skills
# /model anthropic:claude-haiku-4-5-20251001 switch models
# /memory dump current memory snapshot
# /compress force context compression
# /quit
Load into an existing host
Any deepagent-* host with langgraph-stream-parser>=0.2 host conventions can run this agent:
# deepagent-code
DEEPAGENT_AGENT_SPEC="deepagent_hermes.agent:graph" deepagent-code
# deepagent-lab — set the same in deepagents.toml under [agent]
echo 'spec = "deepagent_hermes.agent:graph"' >> deepagents.toml
deepagent-lab
Configuration
deepagent-hermes.toml (project) or ~/.deepagent-hermes/config.toml (global). Layered resolution: defaults < TOML < DEEPAGENT_HERMES_* env < CLI overrides. See SPEC §2 for every field; deepagent-hermes --show-config prints the resolved value + source of each.
Architecture
See SPEC.md for the full 21-section requirements doc. Top-level layout:
src/deepagent_hermes/agent.py— the compiled graph (entry point for hosts)src/deepagent_hermes/config.py—HermesConfig(HostConfig)resolversrc/deepagent_hermes/state.py—HermesState(extendsAgentState)src/deepagent_hermes/reflection.py— closed-loop middleware + review subagentsrc/deepagent_hermes/skills/— SkillLibrary, loader, toolssrc/deepagent_hermes/memory/— frozen-snapshot memory + provider ABCsrc/deepagent_hermes/store/sqlite_fts.py—BaseStorewith FTS5src/deepagent_hermes/search/session_search.py—session_searchtoolsrc/deepagent_hermes/compression.py—HermesCompressionMiddlewaresrc/deepagent_hermes/caching.py—AnthropicCachingS3Middlewaresrc/deepagent_hermes/budget.py—IterationBudgetMiddlewaresrc/deepagent_hermes/tools/— registry + 33 toolsets + 6 terminal envssrc/deepagent_hermes/cron/— daemon +cronjobtoolsrc/deepagent_hermes/plugins/— discovery + lifecycle hookssrc/deepagent_hermes/cli.py—deepagent-hermesentry pointprompts/— verbatim/paraphrased system-prompt building blocks
Status by subsystem
| Subsystem | Status |
|---|---|
| Config + state + agent factory | ✅ working |
| Reflection loop (10-iter / 10-turn triggers, subagent review) | ✅ working — verified live |
| Skill library + agentskills.io validator | ✅ working |
| Skill loader (system-prompt injection + progressive disclosure) | ✅ working |
skill_view / skill_manage / skills_list tools |
✅ working |
| Frozen-snapshot memory (MEMORY.md / USER.md) | ✅ working — verified live (702 bytes written autonomously) |
SQLite FTS5 store + session_search (3 modes) |
✅ working |
MarkdownProvider (bundled, default) |
✅ keyword search over <HERMES_HOME>/memories/notes/*.md — zero deps |
| Iteration budget middleware | ✅ working |
| Compression middleware (13-section template) | ✅ working |
Anthropic system_and_3 caching strategy |
✅ working |
| Tool registry + 33-toolset enum | ✅ working |
LocalEnvironment terminal backend |
✅ working (Git Bash on Windows) |
DockerEnvironment |
✅ working (gated on docker info reachability) |
SshEnvironment |
✅ working (paramiko-backed, behind [ssh] extra) |
SingularityEnvironment |
✅ working (auto-detects singularity / apptainer) |
DaytonaEnvironment / ModalEnvironment |
✅ lazy SDK with defensive attribute probing (extras-gated) |
Cron daemon + cronjob tool |
✅ working (deliverers: local, stdout, agentmail) |
| Plugin loader (4 discovery sources) | ✅ working (13 of 17 lifecycle hooks wired) |
| CLI + v1-essentials slash commands | ✅ working |
| Curator (skill lifecycle) | ✅ basic |
| Bundled skills | ✅ 26 from nousresearch/hermes-agent (MIT, attributed) |
| Self-evolution integration | 📄 docs only (separate offline repo) |
License
MIT. See LICENSE. This project is a faithful reproduction of the design ideas in Nous Research's Hermes Agent — see NOTICE for attribution.
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 deepagent_hermes-0.1.1.tar.gz.
File metadata
- Download URL: deepagent_hermes-0.1.1.tar.gz
- Upload date:
- Size: 1.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bd621ba342f52763149d2666d76b1130e3f9d988535f310db17dfaeff312a511
|
|
| MD5 |
05fb7ce730cbc35dd373b4349237de0a
|
|
| BLAKE2b-256 |
bb38f6714d7244e2970569404ff2b6152ad89e5a188a965db4e4f2d6e129e757
|
File details
Details for the file deepagent_hermes-0.1.1-py3-none-any.whl.
File metadata
- Download URL: deepagent_hermes-0.1.1-py3-none-any.whl
- Upload date:
- Size: 214.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
170f7e7fb0e54c4faca95def7e68aa919eedda41e511bd816c25a9280b2e1d4d
|
|
| MD5 |
eb9647cf51a059bb2d90e301c8437c2a
|
|
| BLAKE2b-256 |
c803e29202971f37756b79ec75d612303d258f4db38a56177db983770872e023
|