Skip to main content

Universal context drift monitor for AI agent sessions

Project description

radogast

Radogast — Context Drift Monitor

Universal static analyzer for AI agent sessions.

Why Radogast

In Slavic mythology, Radogast is the solar deity of the Polabian Slavs — god of hospitality and protection, guardian of travelers and merchants on their journeys. He is depicted in helmet and chainmail, a prophetic bird upon his head, the head of an aurochs on his chest. The prophetic bird watches without sleep; the sun he carries lights the path forward.

We named this tool after him because that is exactly what it does: it illuminates the path of an AI agent through a task. A conversation has a direction — a goal stated at the start. Radogast measures how far the current context has drifted from that origin, whether the key ideas are present and defined, and whether the work is still moving toward the answer. The sun does not bend. If the path has curved away, Radogast will say so.

Universal static analyzer for AI agent sessions. Monitors context drift from a target, measures term coverage, detects process stage via marker words, and warns when a conversation has left the task space.

Works with: 1bcoder, Claude, OpenCode, Codex, aider, Continue.dev, Gemini, pi, nanocoder — any tool that can export message history as JSON.

Install

pip install -e .
# with embedding support (recommended):
pip install -e ".[embed]"

Quick start

# 1. Auto-generate a target from your task description
radogast target derive "develop REST API for visitor tracking at a café" -o task.yaml

# 2. Analyze a session
cat session.json | radogast analyze --target task.yaml

# 3. Watch a directory for live updates
radogast watch --target task.yaml --dir ~/.continue/history/

# 4. Start MCP server (connects to Claude, Continue.dev, Codex CLI)
radogast-mcp

Target YAML format

goal: "develop REST API for visitor tracking at a café"

key_terms: [REST, API, tracking, session, timestamp, visitor]

milestones:
  - name: domain_understood
    markers: [visitor, establishment, entry, exit, timestamp]
    evidence: "definition of visitor as an entry+exit event pair"
  - name: api_designed
    markers: [endpoint, POST, GET, response]
    evidence: "at least one endpoint with schema"

falsification:
  critical_tests:
    - "if visitor is never defined  problem not formulated"
    - "if no formula present  task unsolved"
  minimum_evidence:
    - at least one endpoint specification

out_of_scope: [authorization, billing, UI]

Config (.radogast.yaml)

windows: [1, 3, 5]           # message window sizes
drift_threshold_deg: 40       # alert above this angle
bias_threshold: 3.0           # term imbalance alert
embedding_model: "BAAI/bge-small-en-v1.5"   # fast, 22MB
hybrid: true                  # marker words + embeddings both

MCP tools

Tool Description
analyze_context(messages_json, target_yaml) Full report as JSON
get_drift_score(messages_json, goal, key_terms) Quick angle check
suggest_refocus(messages_json, target_yaml) Actionable suggestions

Output example

[radogast] target: develop REST API for visitor tracking

DRIFT:     23.4°  on_track
STAGE:     api_designed  votes={'api_designed': 3}

TERM COVERAGE  (4/6 defined)  ROUGE-1=0.71
  ✓ REST                  ████████████  defined
  ✓ API                   ██████████░░  defined
  ~ visitor               ████░░░░░░░░  mentioned
  ✗ average time          ░░░░░░░░░░░░  absent
  ✓ timestamp             ██████░░░░░░  defined
  ✓ session               ████████░░░░  defined

BALANCE:  bias=2.1x toward 'REST'

GLOSSARY (3/6 terms):
  REST: architectural style for web services using HTTP...
  session: pair of entry and exit events for one visitor...
  timestamp: Unix epoch in milliseconds, recorded at device level

SUGGESTED:
  → missing from context: average time — add definitions or examples
  → mentioned but not defined: visitor — add explicit definitions

Part of the SIMARGL toolkit

radogast is one of five tools that together form an intellectual development support system:

Tool Role
simargl Task-to-code retrieval — given a task description, finds which files and modules are likely affected, using semantic similarity over git history
svitovyd Project map — scans any codebase and produces a structural map of definitions and cross-file dependencies; exposes it as an MCP server
1bcoder AI coding assistant for small local models — surgical context management, agents, parallel inference, proc scripts
yasna Session memory — indexes conversations from all AI agents so you can find what was discussed, when, and where
radogast Context drift monitor — measures how far an AI agent's conversation has drifted from the original task
  • simargl answers: what code is related to this task?
  • svitovyd answers: how is the code structured and what depends on what?
  • 1bcoder answers: how do I work with local models efficiently?
  • yasna answers: where did I already discuss this?
  • radogast answers: is the AI agent still on track toward the goal?

Together they cover the full development loop: understand the codebase, find relevant history, work with AI locally, remember what was decided, and verify the context stays on target.


About

(c) 2026 Stanislav Zholobetskyi
Institute for Information Recording, National Academy of Sciences of Ukraine, Kyiv
PhD research: «Intelligent Technology for Software Development and Maintenance Support»

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

radogast-0.1.0.tar.gz (20.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

radogast-0.1.0-py3-none-any.whl (22.0 kB view details)

Uploaded Python 3

File details

Details for the file radogast-0.1.0.tar.gz.

File metadata

  • Download URL: radogast-0.1.0.tar.gz
  • Upload date:
  • Size: 20.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.9

File hashes

Hashes for radogast-0.1.0.tar.gz
Algorithm Hash digest
SHA256 6f50905343648917feae8d45ea34a47b76685fb9d9d6b578207524db86d04713
MD5 bd21ee4a27ab65a1bb7b06ebcf090243
BLAKE2b-256 853e860f5365ba1933f4ee921091de137440994a75143749fe47dbaed581c7b3

See more details on using hashes here.

File details

Details for the file radogast-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: radogast-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 22.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.9

File hashes

Hashes for radogast-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f11c3fdb192e33c722fc32f51cd554e604685feb0e76700e69e2ed44e73f64c8
MD5 89e4996a5406721099d7eb51cf775991
BLAKE2b-256 bb6e23e1bc56abb4cea909915188ac2a13650c15592e5c79a9e23f6fffaf4e37

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page