Metis Public Health
Metis Public Health is an AI research companion that runs locally, connecting your papers, notes, meetings, and projects via persistent memory and 30+ specialist agents — all accessed through Claude Desktop or Code. Here's what you can do:
Agent & Session Management
Load agent context, log/retrieve run history, bootstrap and persist sessions, write self-critique reflexions, and run the full 11-stage Metis pipeline for intelligent request routing.
Project & Task Management
Create, archive, unarchive, remove, and detect projects; load project context briefs; update project memory. Manage tasks with filtering by status, project, owner, recurrence, and due dates.
Literature & Knowledge
Search a curated public health literature database by disease, method, geography, or keyword. Archive/remove library items, search markdown notes, and perform local vector/RAG semantic search on PDFs.
Ideas, Journal & Daily Notes
Capture ideas with auto-tagging and cross-pollination, add journal entries with mood/energy extraction, maintain a rolling daily note, and ingest bulk ideas from documents.
Memory System (5 Layers)
Episodic (events), semantic (concepts), procedural (workflows), working memory (session scratchpad), and a human-curated memory palace — all searchable via vector + keyword fusion.
Cross-Pollination & Brainstorming
Find connections across library, meetings, notes, and news; assemble multi-source brainstorm context automatically.
News & Publications
Track new publications by topic, mark as read, manage tracked topics, and generate/retrieve daily intelligence briefs.
Self-Improvement Loop
Propose, review, approve, or reject agent skill improvements; agents critique their own runs to improve over time.
Data Safety & Security
Scan for PII (11 patterns, 4-level classification), anonymize text, log consent/audit events, probe for prompt injection, set network access policy (strict/normal/offline), and load constitutional policy rules.
File & Folder Management
Read files, list folders, track/untrack files, scan for changes, register project folders, manage a document basket, and promote basket items to projects.
Knowledge Graph
Find BFS paths between notes and explore connected knowledge clusters.
Meetings & Transcription
Transcribe meeting recordings locally using Whisper with optional speaker diarization.
Image Generation
Generate images via Gemini or HuggingFace models and list previously generated images.
User Configuration & Thinking Profile
Manage user config and preferences, specialist contexts, contacts, and a personal glossary. Record behavioral signals to build and update a personalized thinking profile.
Observability & Backup
OpenTelemetry-style tracing for pipeline debugging; live SQLite backups with AES-256-GCM encryption/decryption.
🩺 This is the Public Health & Epidemiology edition
Metis_PH ships with a pre-loaded public-health knowledge layer — WHO guidance, global-health reports, and epidemiology/methods references — so you can ask grounded, cited questions on day one without building a corpus first. The domain-agnostic base shell (
SVerITG/Metis) is identical in every other way; it ships empty and builds your field's knowledge layer through the setup questionnaire.
See it in action
Related MCP server: LocalNest MCP
Why researchers trust it
📚 It cites your own sources. Every knowledge answer is drawn from your indexed library, with document- and page-level citations — not the model's guesses.
🔗 It connects everything you know. Every paper, meeting transcript, idea, note, journal entry and task is linked to the rest of your work. The grant you write today surfaces a method paper from last year and a meeting note from March — you never go looking; Metis brings it to you.
🧠 It routes to the right expert. Ask in plain language, and Metis hands the work to the right one of 30+ specialist skills — Librarian, Methods Coach, Writing Partner, Meeting Memory, Epidemiologist, Course Builder, and more.
🔁 It improves itself. After every task it logs what worked and what fell short; each week it drafts improvements to its own behaviour and waits for your approval. Most MCP servers are static — Metis gets sharper the longer you use it.
🚫 It refuses to invent. Ask about something that isn't in your library and Metis tells you so, instead of fabricating a plausible-sounding answer. (This grounding behaviour is covered by an automated test.)
🔒 It stays on your machine. Local embeddings, local database, local files. Your papers, patient-adjacent data, and unpublished work never leave your computer.
🎥 See it in action above — the dashboard, a tour of the tabs, the silent layer into Claude Desktop, and Metis improving its own work.
Easiest way to try it: install Claude Desktop and run the 3-step setup — a demo workspace is pre-loaded, so you start with something to explore instead of a blank screen.
Who is this for?
🔬 I'm a researcher
No programming background needed. Install in minutes, start working immediately. Everything Metis does is explained in plain language.
⚙️ I'm a developer
Open-source, extensible, well-architected. Build domain packs, add agents, extend the MCP server, or deploy for your institution.
What is Metis?
Metis is a research companion built on top of Claude that keeps your data on your own machine. It gives every AI conversation a persistent memory of your domain, your papers, your projects, and your working history. It routes your requests to the right specialist, does the work, records the result, and returns a plain answer — without requiring you to prompt or configure anything.
The app runs on your machine and your data stays there — your documents, notes, embeddings and memory never leave it. The reasoning is powered by Claude, so the text you choose to send for analysis goes to the Anthropic API; everything else is local. (See Data Protection for exactly what leaves your machine, and when.)
The short version: imagine an AI that already knew your field and your literature, connected every paper, meeting, idea and note you've captured, sent each request to the right specialist — and got sharper about your work, and about itself, the longer you used it. That's Metis.
How it works
Metis is not a separate app you log into. It's a small service that runs quietly in the background and connects Claude to your research — your papers, your memory, your projects.
A background service (the "MCP server") starts with your computer. It's the bridge between Claude and your files — you never interact with it directly.
You talk to Metis through Claude, two ways:
Claude Desktop (easiest): open it and pick a Metis prompt (e.g. Metis, Metis Doctor) from the prompt menu — or just ask.
Claude Code (terminal): type
/metisfollowed by your request.
You ask in plain language. Metis works out which of its 30+ specialists should handle it, does the work using your library and memory, and answers — citing sources.
That's it. There's nothing to learn before you start; the dashboard is optional visibility on top of all this.
Design Philosophy
Every AI conversation starts from zero. You spend ten minutes re-explaining your context, and when the session ends, it's gone. Generic AI tools are powerful but stateless — they know everything about the world and nothing about you.
Metis is built on one idea: the AI should know you. And it should keep getting better — on its own.
Not just your name — your domain, your literature, your projects, your preferred working style, your open questions, your meeting notes from last month, and the paper you added to your library yesterday. The longer you use Metis, the better every response gets. Not because the AI changes — because Metis knows you better.
You don't need to follow developments in AI. Metis does that for you. Every week, Metis reviews its own performance across all your sessions, identifies where it could have done better, drafts improvements to its own behaviour, and waits for your approval before applying them. As better methods and models become available, those improvements are folded in the same way — always proposed for your approval, never applied behind your back. As a researcher, you focus on your research. Metis handles keeping itself sharp.
The core mechanism is cross-pollination. Every time you capture an idea, add a paper, record a meeting, or complete a task, Metis connects it to everything else in your research universe. A paper you indexed a year ago surfaces when you're writing a grant today. A meeting note from March links to the idea you captured this morning. An open question from six months ago connects to a new paper that just came out. These connections happen automatically, in the background, without you having to search for them. This is what makes Metis a research companion rather than a search tool — it thinks across your entire body of work so you don't have to hold it all in your head.
This is genuinely new ground. The individual components — local language models, retrieval-augmented generation, agent routing, vector search — all exist independently. What Metis presents is a coherent integration of all of them, purpose-built for the specific demands of research work: long timelines, sensitive data, deep literature, and knowledge that accumulates over years. A system that grows with you, and surfaces connections for you — rather than starting from zero every session. To our knowledge, nothing quite like this exists as a unified, locally-running, researcher-facing system.
Three levels — choose your entry point
Level | What it is | Best for |
☁️ MCP server only | A background service that runs alongside Claude. Persistent memory, session awareness, 30+ specialist agents — no dashboard, no visible app. | Researchers who use Claude already and want it to know their work |
📊 With the dashboard | Full visibility across your research life — papers, ideas, meetings, tasks, projects, all connected. Built for cross-pollination (ideas linking to literature) and brain off-loading (tracking leaving your head, entering the system). | Researchers who want a complete research operating environment |
🌐 Metis OS | Connects to email, calendar, data systems, and institutional infrastructure — a unified intelligence layer for your entire working environment. | The longer vision. Still in development. |
Where things stand today: The MCP server, 30+ agents, and the 10-tab dashboard are fully operational and used daily. The one-click installer and the pre-loaded domain knowledge layer are still being refined. This is a working system — not vaporware — but it is also not finished. If something breaks, please open an issue. That feedback shapes what gets built next.
For Researchers
No programming background needed. Everything below is point-and-click or copy-paste.
How Metis is powered — you choose (you won't burn API tokens just by using it)
Metis runs two ways, and you pick:
On your Claude subscription — no API key, no per-token bills. This is the everyday path: you talk to Metis through Claude Desktop or Claude Code, and the dashboard's "✦ Update with Claude" / brainstorm buttons open Claude Desktop on your subscription. Most people use Metis entirely this way.
With an Anthropic API key — only needed for things that run while you're not there: the scheduled morning scan and automated brief generation. Pay-per-token, typically a few cents a day.
With a local model (Ollama) — optional, for fully-offline helper tasks (e.g. the data assistant).
The installer asks for an API key so automation can run, but you can skip it and use Metis on your subscription alone. Nothing in the interactive experience requires the API.
Install in 3 steps
Step 1 — (Optional) Get an Anthropic API key — only for unattended automation (free, 2 minutes)
Go to console.anthropic.com and create an account.
Click API Keys → Create Key. Copy the key (it starts with
sk-ant-…).Keep that tab open — the installer will ask for it once.
The key stays on your computer. It is never uploaded or shared.
Windows
Double-click the installer. The wizard walks you through:
Full or AI only — Full gives you the AI assistant + 10-tab research dashboard (~15 min). AI only is faster (~5 min) and you can add the dashboard later.
Your projects — Tell Metis what you're working on. It creates a tracking record for each project, writes a context file into the project folder, and registers it in Claude Desktop automatically.
Demo workspace — Pre-loads realistic example projects, meetings, literature, and tasks so you can explore every feature immediately. Recommended for first-time users.
API key — Paste it once.
Everything else is automatic. Claude Desktop opens at the end with Metis ready to go.
Requirements: Windows 10 or 11 · Internet connection · API key
macOS or Linux
Open Terminal and paste:
bash <(curl -fsSL https://raw.githubusercontent.com/SVerITG/Metis_PH/main/system/mcp-server/setup-mcp.sh)The script asks two questions (Full or AI only, demo workspace) and does the rest. Registers Metis with Claude Desktop and Claude Code automatically. Works on Ubuntu 20/22/24, Debian, and macOS.
Requirements: Python 3.10–3.13. The installer prefers
uv(which downloads its own Python 3.12 — no system packages needed). Ifuvisn't available it falls back to your system Python; on a bare system you may needsudo apt install python3-venv. Very new Python (3.14+) isn't supported yet — some packages don't publish wheels for it. If you hit "ensurepip is not available", installuv(the line above) orpython3-venvand re-run.
MCP client configuration
The installer registers Metis with Claude Desktop and Claude Code automatically — you normally don't need to edit any config by hand. The blocks below are for reference (and for MCP directories): they show how the metis-rc server is wired in.
Metis is not a one-line
npx/uvxserver. Run the installer first — it builds the local virtual environment, initialises the database, and generates the launch script (run.sh) the configs below point to.
Step 0 — install (builds the venv + DB, generates run.sh):
bash system/mcp-server/setup-mcp.shClaude Code (any OS) — done for you by the installer, or add it manually:
claude mcp add metis-rc ~/.local/share/metis-mcp/run.shClaude Desktop — macOS / Linux (native) — in claude_desktop_config.json:
{
"mcpServers": {
"metis-rc": {
"command": "bash",
"args": ["/home/<you>/.local/share/metis-mcp/run.sh"]
}
}
}Claude Desktop — Windows + WSL — in claude_desktop_config.json:
{
"mcpServers": {
"metis-rc": {
"command": "wsl",
"args": ["-e", "/home/<you>/.local/share/metis-mcp/run.sh"]
}
}
}Replace
<you>with your username. The generatedrun.shsetsMETIS_RC_ROOT(your Research Cortex folder) and launchespython -m metis_mcp.serverfrom the installed virtual environment — no API key is required to run the server itself.
What you get on day one
Feature | What it does |
30+ specialist agents | Librarian, Epidemiologist, Methods Coach, Writing Partner, Meeting Memory, Course Builder, Career Coach, Critic, and more — each an expert in their domain |
Grounded answers | Every knowledge question is automatically answered from your own indexed document library with page-level citations — not AI guesses |
Library management | Import PDFs, sync Zotero or Mendeley, ask "what do my papers say about X?" — cited answers from your own library |
Morning intelligence brief | Every morning: new papers on your exact research topics, field news, surveillance alerts, and a focus recommendation — fully personalised |
Live meeting assistant | Follow along in real time, or paste a transcript — get structured notes, action items, and project cross-references automatically |
Project tracking | Every project gets a tracking record, a context file in its folder, and integration with Claude Desktop. The Update button scans all your project folders for activity. |
Voice capture | Record anywhere, transcribe locally (no API, no upload), route to ideas, journal, or notes |
10-tab dashboard | Today · News · Knowledge · Meetings · Learning · Work · Thinking · Planner · Teach · Metis — all live, all local |
Data protection | Six security layers + the |
Cross-pollination | Every idea, paper, meeting, and task is automatically connected to everything else in your research universe. Metis surfaces links across time — a paper from last year, a meeting note from March, a question you logged at a conference — without you searching for any of it. |
Token tracking | Every agent run shows exactly what it cost — which specialist was used, how many tokens, what model. The dashboard Today tab has a live token pulse so you always know your daily usage. Most daily tasks stay under a few cents. |
Tool subset loading | Metis registers 187 MCP tools, but exposing all of them to Claude on every session wastes context. By default, Metis loads only the tools relevant to the current agent — 90 tools for News Radar, 107 for the Librarian, ~65 for a general session. Each tool definition costs tokens; loading fewer means more room for actual work and lower per-session cost. Disable with |
Metis evolves — you don't have to | Every week, Metis reviews its own session logs, identifies where it underperformed, and drafts behaviour improvements. You approve or reject them — nothing changes without your sign-off. New capabilities are folded in the same way. You focus on your research; Metis keeps itself sharp. |
Grows with you | Every agent run adds to your profile. A question asked after six months of use gets a meaningfully better answer than the same question on day one — not because the AI changed, but because Metis knows you better. |
Key Workflows
Morning
Wake up
└─ Metis scanned overnight
├─ New papers on your configured research topics
├─ Surveillance alerts and field news
├─ Tasks due today, overdue items
└─ Suggested daily focus based on your open projects
└─ Open dashboard → read morning brief → start workLiterature
New paper (PDF / DOI / Zotero / Mendeley import)
└─ Librarian indexes it
├─ Added to knowledge graph
├─ Cross-pollinated with existing papers, past ideas, meeting notes
└─ Available for cited semantic search immediately
└─ Ask: "What do my papers say about X?"
└─ Answered with inline citations from your own libraryMeetings
Meeting ends
├─ Paste transcript (Teams / Zoom / any audio file)
└─ Meeting Memory agent processes it
├─ Structured notes with context
├─ Action items: who does what, by when
├─ Cross-references to your projects and open questions
└─ Follow-up tasks auto-added to Work tabIdeas and writing
Idea surfaces
└─ Ctrl+K → capture instantly (i: idea · n: note · t: task · q: question)
└─ Metis cross-pollinates immediately
└─ Related papers + past ideas surfaced automatically
└─ Writing Partner → draft · Librarian → sources · Methods Coach → check argumentTeaching and courses
Course topic defined
└─ Course Builder
├─ Generates lessons, slides, assessments, question banks
├─ Flags new papers relevant to your course automatically
├─ Gap analysis against current literature
└─ Spaced repetition for your own knowledge maintenanceThe Dashboard
The 10-tab dashboard runs locally at http://127.0.0.1:8080. No account, no cloud, no subscription.

The Today tab — morning briefing, active project, progress, news radar, and quick stats. Everything personalised to your research domain.
Tab | What it does |
Today | Morning brief, priority task queue, news rail, quick capture ( |
News | Field news, surveillance alerts and RSS signals relevant to your work |
Knowledge | Semantic PDF search, literature cards, knowledge graph, coverage gap analysis |
Meetings | Live assistant, transcript import, action items, cross-references |
Learning | Course progress, spaced repetition, competency map |
Work | Tasks, project cards, activity tracking, one-click open in VS Code / RStudio / Claude |
Thinking | Idea capture, cross-pollination, brainstorm launcher, open questions tracker |
Planner | Kanban board, research timeline, milestones |
Teach | Course Builder, literature alerts, lesson generation, student-facing content |
Metis | Agent run history, self-improvement proposals, system health, identity card |
How Metis Knows You
When you first install Metis, a setup wizard walks you through your profile:
research domain · specific interests · active projects · working style · tools you use · data sensitivity level
This creates your identity card — a living profile that every agent reads before responding to you. It grows over time. Every session adds context. Every idea you capture tells Metis what you're thinking about.
A question asked after six months of use gets a meaningfully better answer than the same question on day one — not because the AI changed, but because Metis knows you better.
Data Protection
Researchers handle sensitive data. Most AI tools don't take that seriously.
Patient data, embargoed results, unpublished findings — these should never leave your machine. Metis was designed with this in mind from the start.
What leaves your machine (and when):
Service | What | When | Optional? |
Anthropic Claude API | Text you send for analysis | On demand | Required for AI |
PubMed / OpenAlex | Your research search keywords | Daily morning scan | Yes |
Zotero | Library metadata (titles, abstracts, tags) | Daily sync | Yes |
CrossRef | DOI queries | On demand | Yes |
HuggingFace | Model name only — downloads embedding models | First run | Yes |
Everything else — your documents, voice recordings, PDF text, meeting notes, patient-adjacent data — stays on disk.
Security layers:
Layer | What it does |
Pre-tool hook | Checks every tool call for injection attempts and restricted paths; peeks at a data file's header locally before it's read and asks you to confirm before individual-level data is loaded into the conversation |
PII detection | 11 checks, 4-level classification. Sensitive data is classified and refused at pipeline entry |
Injection probe | Detects prompt injection in external content (papers, transcripts) |
Constitution | 14 machine-readable rules applied to every deep agent run |
Red lines | 5 non-overridable rules enforced at code level — no override possible |
AES-256 encryption | All backups encrypted at rest |
The recommended pattern for sensitive data: send code, not data.
The strongest protection isn't a scanner — it's never putting the raw data in a prompt at all. Metis is built for this. Ask it for an analysis script (R or Python); you run it on your own machine against your real data; and only the derived outputs — variable names, value counts, summary tables, model coefficients, a data dictionary — come back to Metis. Claude reasons over the shape of your data, never the records.
Your real dataset (patient rows) ── stays on your machine, never sent ──┐
│ you run Metis's R/Python script locally │
▼ │
Derived metadata (column names, unique values, Table 1, model summary) ── safe to share ──► Metis
│ │
▼ │
Metis builds the dashboard / writes the methods / interprets the model ◄────────┘This is exactly how the dashboards and analyses in our own work were built: the raw surveillance data never left the machine, yet Metis could profile it, name every variable, list unique values, and generate a full dashboard.
Just run /safe-analysis (Claude Code or Claude Desktop) and Metis walks you through it end-to-end — it proposes the local script, tells you exactly which metadata to paste back, and never asks for raw rows. Two backstops sit underneath: the pre-tool hook peeks at a data file's header locally and asks before any individual-level data is read into the conversation, and the Data Guardian (PII scan + 4-level classification at pipeline entry) catches sensitive content that slips into a prompt anyway. With the pattern above, neither usually has to fire.
How Metis Stays Current — So You Don't Have To
AI is moving fast. New models, new capabilities, new research tools appear every month. Most researchers don't have time to follow it. Metis is designed to handle this for you.
After every agent run, Metis logs a reflexion — what went well, what fell short, what context was missing. Every week it aggregates these into themes. Every week it drafts behaviour improvements with a clear rationale. You review the proposals in the Metis tab — one click to approve, reject, or edit — and the approved changes are written to disk.
This means Metis gets better at working with you specifically, week after week. It also means that as new AI developments become available and get integrated into Metis, you receive the improvements without having to do anything. Your job is your research. Metis's job is to stay sharp.
The self-improvement loop in detail:
After every agent run — reflexion logged: what went well, what could improve, what was missing
Weekly — themes extracted across all sessions; patterns identified
Proposal drafted — a concrete proposed change to agent behaviour, with reasoning
You review in the Metis tab — approve, reject, or edit before anything applies
Applied with backup — the update is written with a timestamped rollback point
No change to Metis's behaviour ever happens without your explicit approval. The system proposes; you decide.
For Developers
This section assumes familiarity with Python, Git, and the command line.
Architecture
flowchart LR
U([Researcher])
subgraph Harness["AI Harness (Claude Code / Desktop)"]
METIS[Metis\nrouter agent]
AGENTS[Specialist agents\n30+ agents]
WATCHERS{{Watchers\nData Guardian · Cybersecurity}}
end
subgraph Platform
MCP[MCP Server\n187 tools\nFastMCP]
DASH[Dashboard\nFastAPI + HTMX]
DB[(SQLite\nWAL mode)]
end
subgraph Memory
EPIS[Episodic]
SEM[Semantic\nvector search]
REFLEX[Reflexion log]
end
Skills[/CLI Skills\n/metis · /librarian · …/]
U -->|asks| METIS
U -->|clicks| DASH
METIS -->|routes to| AGENTS
AGENTS -->|uses| MCP
MCP --- DB
DASH --- DB
WATCHERS -.guards.-> AGENTS
AGENTS -->|writes| REFLEX
REFLEX -->|proposes edits to| AGENTS
MCP --- Memory
Skills --> METIS
style WATCHERS fill:#fff4e6,stroke:#9a7b3c
style REFLEX fill:#eef4f1,stroke:#2d4a3a,stroke-dasharray:3 3Stack
Layer | Technology |
AI harness | Claude Code, Claude Desktop (primary); Gemini (experimental) |
MCP server | Python 3.10+, FastMCP, runs in local venv |
Dashboard | FastAPI + HTMX + Jinja2 — no JavaScript framework |
Database | SQLite WAL mode, 65 tables |
Vector memory | sqlite-vec + nomic-embed-text-v1.5-Q (768 dims, local ONNX) |
Semantic PDF search | sqlite-vec — local PDF chunk index, no external API |
Host OS | Windows + WSL2 (Ubuntu 20/22/24) · macOS · Linux |
Memory — 5 layers
Layer | What it stores |
Episodic | Session events and observations (discovery · decision · implementation · issue) |
Semantic | Vector-indexed content (sqlite-vec + nomic-embed-text-v1.5-Q, 768 dims) |
Procedural | Skill files and agent contracts — the agent's persistent behaviour |
Working | Active session context and current project focus |
Reflexive | Reflexion log and improvement proposals |
Knowledge Layer & Grounded Answers (RAG)
When you ask a knowledge-intensive question, Metis retrieves relevant passages from your indexed document library before the specialist agent answers. The agent grounds its response in what it can read from your library — not only what it was trained to recall.
You ask Methods Coach:
"Which variance estimator should I use for my Poisson MLM with overdispersion?"
Metis retrieves before routing:
→ Leyland (2020) Multilevel Modelling for Public Health, p.142 — score 0.87
→ Bates lme4 vignette, p.28 — score 0.71
Methods Coach answers grounded in those passages, citing both sources.Component | Details |
Embedding model |
|
Vector store |
|
Chunking | 3,200-character chunks, 400-character overlap |
Score threshold | Chunks below 0.4 similarity dropped before injection |
Build your field's knowledge layer. On first setup, the wizard's research-background questionnaire briefs the Background Maker, which harvests, scrubs, and indexes your discipline's literature into the local RAG store — so every agent answers from your corpus, cited. Grow it anytime with /background build <topic>.
Pre-loaded knowledge layers (this edition):
Layer | Documents | Covers |
Public Health Background | 34 | WHO guidelines, global health reports, social determinants, NCDs, maternal & child health |
Epidemiology & Methods | 10 | STROBE, WHO Basic Epi, Leyland MLM, Bates lme4, PRISMA 2020, SaTScan, CIFOR |
Security Layers (detail)
pre-tool-use.mjs— 13 injection patterns, domain allowlist, path restrictions (every tool call)guardrails.py— injection probe on all external content (papers, web, transcripts)safety.py— 11 PII checks, 4-level classification, sensitive data refused at pipeline entryconstitution.md— 14 machine-readable rules for deep and chained agent runsred-lines.md— 5 non-overridable rules enforced at code level
Token Efficiency
Model routing — Haiku for triage/summaries, Sonnet for most work, Opus only for deep reasoning; most daily usage never touches Opus
Surgical context assembly — each agent gets only the context relevant to its task, not full history
Max-turns guardrail — stops at 20 turns, prompts
/clearSession handoff — under 3 KB state capture at session end; no re-paying for context already established
Token pulse widget — real-time usage visible in the dashboard
Cross-AI Support
Harness | Status |
Claude Code | ✅ Primary — full MCP + skills + hooks |
Claude Desktop | ✅ Primary — full MCP + memory; no CLI skills |
Gemini 2.0+ | 🔬 Experimental |
OpenAI / Cursor | 🟡 Partial — MCP tools only |
Installation Options
Option 1 — Single command (Linux, macOS, WSL)
bash <(curl -fsSL https://raw.githubusercontent.com/SVerITG/Metis_PH/main/system/mcp-server/setup-mcp.sh)Detects Ubuntu 20/22/24, Debian, macOS Homebrew. Creates venv, installs all dependencies, registers with Claude Code and Claude Desktop. Idempotent — safe to re-run.
# Profile overrides (skip the interactive menu):
METIS_PROFILE=light bash <(curl -fsSL ...) # MCP server only (~5 min)
METIS_PROFILE=standard bash <(curl -fsSL ...) # MCP + dashboard (~15 min)
METIS_PROFILE=full bash <(curl -fsSL ...) # Standard + scheduler (~25 min)Option 2 — Clone and install (any platform)
git clone https://github.com/SVerITG/Metis_PH.git
cd Metis_PH/system/mcp-server
bash setup-mcp.shOption 3 — Manual
git clone https://github.com/SVerITG/Metis_PH.git
cd Metis_PH/system/mcp-server
python3 -m venv .venv && source .venv/bin/activate
pip install -e "."
export METIS_RC_ROOT="$(pwd)/../.."
export ANTHROPIC_API_KEY="sk-ant-..."
python -m metis_mcp.server # MCP server
cd ../app-py && bash run.sh # Dashboard → http://127.0.0.1:8080Option 4 — Docker (platform test matrix)
# Full platform test — Ubuntu 24/22 + Debian in parallel
docker compose -f system/install/docker/docker-compose.test.yml up --build
# Production stack
docker compose -f system/install/docker/docker-compose.yml up -dRegister with Claude Code
~/.claude/settings.json:
{
"mcpServers": {
"metis-rc": {
"command": "/home/<username>/.local/share/metis-mcp/run.sh"
}
}
}Register with Claude Desktop (Windows + WSL)
%APPDATA%\Claude\claude_desktop_config.json:
{
"mcpServers": {
"metis-rc": {
"command": "wsl.exe",
"args": ["-e", "bash", "/home/<username>/.local/share/metis-mcp/run.sh"]
}
}
}Configuration
File | Controls |
| Domain, interests, style — generated by setup wizard |
| 14 rules applied to every deep/chain run |
| 5 non-overridable rules |
| Model routing, handoff thresholds |
| Behavioural contract per agent — directly editable |
| Security gate on all tool calls |
Dependencies
Package | Purpose |
| MCP protocol |
| Dashboard |
| Local vector search |
| Local embeddings (no API) |
| RSS feed parsing |
| User config |
| Async HTTP |
| Data analyst tools |
| AES-256-GCM backup encryption |
| Zotero sync |
| Mendeley BibTeX import |
| Claude API |
Editions and Roadmap
Metis ships in distinct editions — a domain-agnostic base shell, and domain packs that add field-specific content on top.
Repository | Status | What it is |
✅ Live (v1.0) | Domain-agnostic base shell. Full architecture, no domain content. Clone this to build your own edition. | |
✅ Live (v1.0, this repo) | Public Health & Epidemiology — MCP server, 30+ agents, dashboard, knowledge layer | |
🧬 Planned | Biomedical Sciences | |
🏥 Planned | Clinical Sciences | |
Metis [Community] | 🌍 Open | Domain packs for other research fields — contributions welcome |
Metis Institute Edition | 🏛 Future | Multi-user, shared knowledge base, institutional deployment |
What's in each domain edition: pre-configured journals + RSS feeds · specialist agents · domain ontology · curated background knowledge library
Want to build a domain pack? Fork
Metis, add your field's knowledge library, agents, and RSS feeds, and open a PR.
Course Packages (Coming Soon)
Standalone course packages you can drop into any Metis installation:
Package | What it covers |
Sampling Strategies | Probability and non-probability sampling, sample size, complex survey designs, weighted estimation |
Spatial Epidemiology | Spatial autocorrelation, kernel density, SaTScan, LISA, disease mapping in R and GeoDa |
Genomic Surveillance | Pathogen sequencing in public health, phylogenetics, WGS pipelines, Nextstrain |
Open an issue with label course-package to pilot or contribute.
Development Status
Area | Status |
MCP server (187 tools) | ✅ Operational, used daily |
30+ specialist agents | ✅ Operational, used daily |
10-tab dashboard | ✅ Operational, some features in active development |
Windows .exe installer | 🔧 In refinement |
Docker images | ✅ Test matrix working |
Domain knowledge layer (Metis_PH) | 🔧 Actively being expanded |
Automated daily tasks (APScheduler) | 📋 Next |
Test suite | 📋 Next |
Telegram capture bot | 📋 Planned |
Metis OS (calendar, email integration) | 🌐 Future vision |
Contributing
Metis is designed to grow beyond one domain and one researcher. Contributions are welcome — especially from researchers who use it and know what's missing.
See CONTRIBUTING.md for detailed guidelines.
Most Wanted
Domain packs — the most impactful contribution. A domain pack adds: key journals + RSS feeds · specialist agents · a domain ontology · a curated background library
Domain | Status |
Public Health & Epidemiology | ✅ Included |
Social Sciences | 🔬 Planned |
Biomedical / Clinical Research | 🔬 Planned |
Environmental Science | 🔬 Planned |
Economics and Development | 🔬 Planned |
Psychology and Behavioural Sciences | 🔬 Planned |
Education Research | 🔬 Planned |
Nursing and Allied Health | 🔬 Planned |
Other high-impact contributions:
Translations — the wizard and skill files are English-only; translations into French, Dutch, Spanish, German would open Metis to many more researchers
Installer testing — Windows
.exeand PowerShell on managed machines, corporate environments, and varied hardware; reports of what works and what breaks are valuableNew agents and skills — specialist agents for use cases not yet covered
Security verification — independent review of the data-stays-local guarantees (what's kept on the machine vs. sent to the Claude API), PII detection, hook behaviour, and constitution enforcement; if you find a gap, open a private issue
Multi-AI support — better Gemini and local model (Ollama) support, especially for offline research environments
Bug reports and UX feedback — if something doesn't work for your workflow, say so
Changelog
Post-v1.0 — June 2026
What changed |
Code Repository — a reproducibility / code-reuse layer: register scripts, data dictionaries (variable names, types, unique values) and dataset treatments, then |
Projects in the registry + cross-pollination — project listing now reads the project registry (every project, not just folders on disk); brainstorms and cross-pollination now draw on your registered projects and notes, not only library/news. |
Brainstorm + brief upgrades — a brainstorm creativity dial (Grounded/Balanced/Bold) and a scoped menu (this work · a topic · mindmap · cluster) that hand off to Claude Desktop primed with your work; a Daily ↔ Weekly morning-brief toggle; an idea mindmap on the Reflection tab; and an "Improve Metis (OODA)" button on the Metis tab. |
Sensitive-data workflow ( |
Data Guardian hardening — the pipeline PII scanner now runs all 11 patterns (names, DOB, passport, medical record numbers, national ID numbers, case/registry identifiers, + the original five) through one shared scanner used by both the tool and the pipeline, so they can't drift; covered by a unit-test suite. |
Pre-tool data-file guard — before a |
Honest positioning — dropped the "local-first/local AI" framing (reasoning runs on the Claude API); copy now states plainly that your data stays on your machine while reasoning uses Claude. |
Desktop project-tracking + file-tracking fixes — the Desktop router now registers tracked projects; repaired a recursion bug that had broken file tracking. |
Post-v1.0 — May 2026
What changed |
Unified project intelligence system — unlimited projects with categories and folder paths in all installer paths; CLAUDE.md written to each project folder; Claude Desktop auto-registration; activity scanner detects git commits, modified files, and todo completions; Claude Code stop hook reports active project to dashboard |
Three-path intelligent setup wizard — browser wizard (unlimited projects, categories), terminal wizard (Linux/macOS), and Inno Setup wizard (Windows .exe) all backed by Claude API persona generation |
Docker test matrix — Ubuntu 24/22 + Debian + light profile running in parallel; mandatory pre-release gate in Release Coordinator |
Today surface restructure — session handoff strip, 7-metric ledger, three-tier priority queue, 2×2 research quadrant layout, time-of-day adaptive morning brief |
Metis real subagent orchestration — Metis spawns real isolated subagents via the Agent tool, with independent token tracking |
Release Coordinator — proactive git guardian with |
Scheduler fix — library index job corrected (scan_literature_folder in content_scan module) |
Knowledge surface — unified search, coverage gap analysis, knowledge layer browser |
v1.0 — May 2026
First stable release. See system/config/release-notes-v1.0.md for full details.
What shipped |
FastAPI + HTMX dashboard — 9 tabs |
34 specialist agents |
MCP server — 170+ registered tools |
Windows installer (Inno Setup) |
Statistics for Epidemiology course — 12 lessons with spaced repetition |
Startup eval suite + news freshness check |
Auto-handoff brief at 80% context |
AGPL-3.0 license |
Earlier development (Phases 0–9b)
Phase | What shipped |
0–5 | MCP server, 34 agents, CLI skills, config wizard, SQLite (46 tables), 5-layer memory, knowledge graph, Zotero/Mendeley sync |
6–7 | FastAPI + HTMX dashboard — 9 tabs, live partials |
8 | Morning brief, news rail, meeting assistant, voice capture, PaperQA2 PDF search, cross-pollination, token guardrails |
9 | CSS design overhaul — editorial layout, responsive grid, animation |
9b | Self-improvement loop — reflexion aggregation, proposal drafting, approval flow |
M | Conversation memory — session summaries in episodic memory, semantic search across past sessions |
License
AGPL-3.0 for the codebase — use, modify, and fork freely, but any version you run as a service or distribute must also be open-source under AGPL-3.0.
CC-BY-SA 4.0 for course content and learning materials.
Maintenance
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/SVerITG/Metis_PH'
If you have feedback or need assistance with the MCP directory API, please join our Discord server