the-teacher
Enables structured learning with a verified loop: define goals as observable claims, learn through teach-lab-test-gate per claim, and get independently graded by an adversarial examiner to ensure genuine progress.
README
The Teacher
Run learning as a verified loop: interview to build a detailed Target (your goal as observable claims), derive a Path to close the gap, learn through teach → lab → test → gate per claim, get cold-examined by an adversarial verifier, and raise the Target once you match it. A generic engine; ships with a guitar-learning example.
It's a small MCP server + Claude Code skill. The coaching agent teaches; a separate fresh-context examiner subagent grades — so the teacher never certifies itself.
Quickstart
python3 -m venv .venv && .venv/bin/pip install "mcp[cli]" pytest
.venv/bin/pytest # all green
THE_TEACHER_STORE=./store.local.json .venv/bin/python server.py
See Install below to add it to Claude Code.
Install as a plugin (one step) — recommended
The repo is its own plugin marketplace, so Claude Code can install the server and the skill
together. Requires uv on your PATH (it pulls the mcp dependency
on the fly — no venv to manage).
/plugin marketplace add outlast85/the-teacher
/plugin install the-teacher@the-teacher
The coaching skill is then available as /the-teacher:teacher.
Install manually
If you'd rather wire it up by hand (or don't use uv):
git clone https://github.com/outlast85/the-teacher.git
cd the-teacher
python3 -m venv .venv && .venv/bin/pip install "mcp[cli]"
# 1) register the MCP server (per-user; the `--` separator is required)
claude mcp add --transport stdio the-teacher -- "$PWD/.venv/bin/python" "$PWD/server.py"
# 2) install the coaching skill
mkdir -p ~/.claude/skills/teacher && cp skills/teacher/SKILL.md ~/.claude/skills/teacher/SKILL.md
There is no global MCP list — registration is per-user and local. Confirm with
claude mcp list.
How it works
- First run — the coach calls
status(), and if no Target is set it interviews you first: it probes your real goal, decomposes it into 2–6 claims with observablepass_criteria, tags each claimneeds_lab(runnable/software claims require lab evidence to pass), dispatches a fresh-context subagent to review the drafted Target for specificity, then callsset_target. A detailed Target is required before any teaching begins. - Teach → lab → test → gate per claim — for each module the coach teaches the concept,
runs a lab if
needs_lab=true(recording evidence withrecord_progress), asks you to explain the claim cold, dispatches a fresh-context examiner subagent to grade blind, and callsrecord_verdict. Aneeds_labclaim with no logged lab evidence is coerced to non-pass by the server even if the examiner says passed. The claim stays inderive_pathuntil it genuinely passes the gate. - Raise the Target — when
status().matchedis true, the coach congratulates you and offers a harder Target, restarting the loop.
Verifier-independence (the design point)
The examiner is deliberately adversarial (default-to-not-ready, high field standard). What makes the verdict independent of the teacher is context isolation — and that's the only mechanism:
- The verifier is a fresh-context examiner subagent. The coach asks the learner to explain the
module cold, then dispatches a SEPARATE subagent (same model, clean context) whose prompt
contains ONLY the claim, the pass criteria, the learner's explanation, and any lab evidence —
never the coaching conversation. Because that examiner never saw the context it would otherwise
be anchored on, the grade is genuinely decorrelated: real maker/checker, not Reflection. The
coach records it via
record_verdict(..., verdict_source="fresh-context"). This works for any subject, needs zero config, no second model, and no external service. - Discouraged —
same-context: inline grading in the same coaching conversation. If ever used, it's recorded asverdict_source="same-context"andstatus()raises anonly_same_contextwarning when a match is backed solely by it. This is the weak-verifier case; avoid it.
matched in status counts fresh-context verdicts. The server itself never calls any model —
all grading is done by the subagent inside your own client.
Resource URIs use the theteacher:// scheme (e.g. theteacher://target,
theteacher://path, theteacher://progress).
Privacy
Your Target/Path/progress live in a local JSON store (~/.the-teacher/store.json by default,
overridden by THE_TEACHER_STORE) that is gitignored. The repo ships only the generic
example. No personal data is ever committed.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.