An LLM agent that sits next to you through your whole ML pipeline
Project description
mlcompass
An LLM agent that sits next to you through your whole ML pipeline โ from data, through training, all the way to deployment.
๐ง Alpha (v0.5.0) โ under active development. APIs may change before v1.0.
What it does
mlcompass is a single CLI that follows your ML project from data to production, keeping context across every step.
data.csv train.py two runs results.csv production
โ โ โ โ โ
โผ โผ โผ โผ โผ
advise โโโโโบ audit โโโโโบ compare โโโโโบ evaluate โโโโโโบ deploy
watch
Each command writes to and reads from a shared project context
(.mlcompass/), so by the time you reach deploy, the tool already
knows your dataset, your model choice, your training history, and your
evaluation results.
What's in v0.5
Nine commands โ every stage of the ML pipeline, a status inspector, plus a self-driving agent that can pick the right tool for you.
| Command | When you run it | What you get | Status |
|---|---|---|---|
init |
Starting a new project | A .mlcompass/ folder that tracks decisions |
โ v0.1 |
advise |
You have a CSV, what now? | Models to try, features to derive, pitfalls to avoid | โ v0.1 |
audit |
Before you press train | Static analysis of training script (seed, val, optimizer, โฆ) | โ v0.2 |
watch |
While training runs | Plateau / overfit / NaN / divergence (plain log / TB / W&B) | โ v0.2 |
compare |
After several runs | Side-by-side config + final-metric diff with verdict | โ v0.2 |
evaluate |
Training done | Metrics, threshold sweep, confusion matrix, leakage-smell | โ v0.3 |
deploy |
Going to production | Model + deps + target-specific checks + production checklist | โ v0.3 |
status |
Any time | Project metadata, active state, command activity, decisions | โ v0.3 |
agent |
"Just do it for me" | LLM-driven router across the other eight tools | โ v0.5 |
Every command except init, status, and agent keeps a fully
deterministic default path and offers an opt-in --llm flag that adds
a Claude-driven interpretation step on top. The agent command is
the inverse: LLM-first by design, with the eight tools as its hands.
Install
pip install mlcompass
export ANTHROPIC_API_KEY="sk-ant-..." # only needed for --llm modes
Optional extras:
pip install "mlcompass[tensorboard]" # adds tbparse for TB event files
pip install "mlcompass[mcp]" # adds the Claude / Cursor MCP server
pip install "mlcompass[agent]" # adds the self-driving agent (anthropic API)
pip install "mlcompass[agent-claude-code]" # alt agent backend via Claude Code CLI
Use from Claude Desktop / Cursor (MCP)
mlcompass ships a Model Context Protocol server, so any MCP-capable
client (Claude Desktop, Claude Code, Cursor, Continue, โฆ) can call its
eight tools directly โ you describe the situation in natural language,
the assistant picks the right mlcompass_* tool and feeds the result
back into the conversation.
pip install "mlcompass[mcp]"
Claude Desktop (~/Library/Application Support/Claude/claude_desktop_config.json
on macOS, %APPDATA%\Claude\claude_desktop_config.json on Windows):
{
"mcpServers": {
"mlcompass": {
"command": "mlcompass-mcp"
}
}
}
Cursor (.cursor/mcp.json in your project, or ~/.cursor/mcp.json):
{
"mcpServers": {
"mlcompass": {
"command": "mlcompass-mcp"
}
}
}
Restart the client and the eight tools appear:
| Tool | Use it whenโฆ |
|---|---|
mlcompass_init |
Starting a new project |
mlcompass_advise |
Asking the assistant to look at a dataset |
mlcompass_audit |
Asking the assistant to review a training script |
mlcompass_watch |
Pointing the assistant at a training log / TB / W&B run |
mlcompass_compare |
"Which of these two runs is better, and why?" |
mlcompass_evaluate |
"Read these predictions and tell me what they mean" |
mlcompass_deploy |
"Is this model ready to ship to Lambda?" |
mlcompass_status |
"What does this project look like right now?" |
All tools are deterministic โ the assistant reads their structured
output and does its own interpretation, with full access to your
conversation's context. The CLI stays available for scripted use and
for the --llm reasoning modes.
Use as a self-driving agent (CLI)
When you're not in Claude Desktop โ CI runs, cron jobs, an ssh session on a GPU box โ you can let an agent drive the same eight tools from the terminal:
pip install "mlcompass[agent]"
export ANTHROPIC_API_KEY="sk-ant-..."
mlcompass agent "I have data.csv, take me from raw data to a model recommendation"
The agent picks tools (mlcompass_advise, then mlcompass_status,
then โฆ), streams every reasoning step + tool call + tool result to the
terminal, and writes a transcript under
.mlcompass/agent_runs/<id>/transcript.jsonl plus a human-readable
summary.md next to it.
Two backends
| Backend | Dependency | Best for |
|---|---|---|
api (default) |
mlcompass[agent] |
Universal: API key + nothing else. |
claude-code |
mlcompass[agent-claude-code] + the claude CLI on PATH |
Power users already on Claude Code; routes through Anthropic's official Agent SDK. |
# Default โ talks straight to the Anthropic API.
mlcompass agent "Compare run-3 and run-7" --project-path .
# Alt โ routes through your local Claude Code CLI.
pip install "mlcompass[agent-claude-code]"
mlcompass agent "Audit train.py and tell me what to fix" --backend claude-code
# Headless / CI โ skip the y/N permission prompt for mutating tools.
mlcompass agent "Init a new churn project here" --auto-approve
# Cap the safety budget if you're worried about runaway loops.
mlcompass agent "Diagnose this run" --max-turns 10 --model claude-sonnet-4-5
The agent will ask before mutating by default โ the only mutating
tool is mlcompass_init. Read/compute tools (advise, audit,
watch, compare, evaluate, deploy, status) auto-allow. Add
--auto-approve to skip the prompt for headless runs.
Five-minute tour
mlcompass init my-project
# Pre-training
mlcompass advise data.csv --target churn
# Training-time
mlcompass audit train.py # static checks
mlcompass audit train.py --llm # + prioritized synthesis
mlcompass watch train.log # one-shot plain-text scan
mlcompass watch runs/tb_run/ # TensorBoard event files
mlcompass watch wandb/run-001/ # W&B local run directory
mlcompass watch train.log --follow # live tail (plain-text only)
mlcompass watch train.log --llm # + diagnostician
mlcompass watch train.log --llm \ # + permission-gated edits
--apply --config train.yaml # (prompted per change)
# Comparing runs
mlcompass compare run-3 run-7 # deterministic diff
mlcompass compare run-3 run-7 --llm # + hypothesis + next experiment
# Post-training
mlcompass evaluate results.csv # metrics + threshold sweep
mlcompass evaluate results.csv --llm # + assessment + next steps
# Deployment
mlcompass deploy model.pt # model + checklist
mlcompass deploy model.pt --requirements reqs.txt --target lambda
mlcompass deploy model.pt --llm # + production verdict
# Any time โ what's the project look like right now?
mlcompass status
mlcompass status --recent 10 # last 10 decisions
# Let the agent drive the whole pipeline
mlcompass agent "I have data.csv, take me to a deployed model"
mlcompass agent "Compare run-3 and run-7" --backend claude-code
mlcompass agent "Init a new project here" --auto-approve
Example โ advise
mlcompass advise examples/customer_churn.csv
๐ Dataset analysis
Path: examples/customer_churn.csv
Shape: 500 rows ร 8 columns
Target: churn (high confidence)
Task: binary classification (0=98%, 1=2%)
โ Warnings
โข Class imbalance detected (1.6% minority class). Don't optimise
accuracy โ use AUC/F1/recall@k. Consider class_weight='balanced'
or focal loss.
โจ Recommended models (with --llm)
โข XGBoost AUC 0.78 โ 0.83
โข Logistic Regression AUC 0.70 โ 0.74
โข LightGBM AUC 0.78 โ 0.84
Example โ audit
mlcompass audit train.py
๐ Script audit
Path: train.py | Lines: 23 | Frameworks: torch
โ error seed No random seed set anywhere
โ error optimizer L17 Adam does not accept momentum=
โ warning val_split No validation split detected
โ warning grad_clipping L8 LSTM but no clip_grad_norm_
โ warning dataloader L20 DataLoader missing shuffle=
โ warning loss_stability L23 log(x) without epsilon clipping
โน info batch_size L20 batch_size=1 is very small
Summary: 2 error 4 warning 1 info
Eight pure-AST rules:
| Rule | Catches |
|---|---|
seed |
No torch.manual_seed / np.random.seed / set_seed call |
val_split |
No split detected, or split implausibly small |
optimizer |
Adam-family + momentum=, weird lr, SGD without momentum |
loss_stability |
log(x) / np.log(x) without clamp or epsilon |
dataloader |
DataLoader(...) without explicit shuffle= |
grad_clipping |
RNN / Transformer built but clip_grad_norm_ never called |
eval_mode |
model.train() appears but .eval() never does |
batch_size |
Implausibly small (<4) or huge (>4096) |
Example โ watch
mlcompass watch train.log
๐ Watch report
Log: train.log
Snapshots: 9
Last epoch: 7
Findings: 1 warning
Recent metrics (last 8)
โโโโโโโโโฌโโโโโโโโโโโโโฌโโโโโโโโโโโฌโโโโโโโโโโ
โ Epoch โ train_loss โ val_loss โ val_acc โ
โโโโโโโโโผโโโโโโโโโโโโโผโโโโโโโโโโโผโโโโโโโโโโค
โ 0 โ 0.65 โ 0.68 โ 0.612 โ
โ โฆ โ โฆ โ โฆ โ โฆ โ
โ 7 โ 0.08 โ 0.59 โ 0.773 โ
โโโโโโโโโดโโโโโโโโโโโโโดโโโโโโโโโโโดโโโโโโโโโโ
โ warning overfitting L7 train_loss dropped -0.17 but val_loss
rose +0.11; current gap is 0.51
Four detectors:
| Rule | Triggers when |
|---|---|
nan |
Any loss-like metric becomes NaN or ยฑInf |
divergence |
Train loss jumps โฅ10ร between consecutive snapshots |
plateau |
Primary loss flat across the last 5 snapshots |
overfitting |
Train falling, val rising, with a meaningful gap |
Add --follow to tail the log file and surface new findings live.
Example โ compare
mlcompass compare run-3 run-7
๐ Run comparison
Run A run-3 (baseline) ยท 20 epochs
Run B run-7 (lower-lr-more-dropout) ยท 20 epochs
Final-epoch metrics
Metric Run A Run B ฮ (B โ A) Winner
train_loss 0.18 0.24 +0.06 A
val_acc 0.79 0.87 +0.08 B
val_loss 0.42 0.28 -0.14 B
Config differences
dropout 0.1 0.3
lr 0.001 0.0003
โ๏ธ Mixed result: A wins 1, B wins 2, 0 tie(s).
Why mlcompass
The ML ecosystem already has great tools โ but each owns one slice of the pipeline, and none of them advise:
| pandas-profiling | W&B / TensorBoard | Cursor / Devin | mlcompass | |
|---|---|---|---|---|
| Analyzes raw data | โ | โ | โ | โ |
| Recommends models + features | โ | โ | partial | โ |
| Audits training scripts | โ | โ | reactive | โ |
| Watches training in real time | โ | dashboard | โ | โ |
| Diagnoses problems proactively | โ | โ | reactive | โ |
| Persistent project memory | โ | per-run | โ | โ |
| Permission-gated actions | โ | โ | partial | first-class |
mlcompass is the advisor that sits next to all of these tools โ not a replacement for any.
How it works
Built on agentlite โ a small Claude agent library โ mlcompass uses one deterministic analyzer per command (pure pandas / pure AST / pure log parser) plus an optional LLM agent layer that runs on top of the analyzer's structured output.
cli.py
โ
โโโโโโโโผโโโโโโโฌโโโโโโโโโโฌโโโโโโโโโโโ
โผ โผ โผ โผ โผ
init advise audit watch compare
โ โ โ
โผ โผ โผ
(--llm) (--llm) (--llm)
priori- diagnos- hypothes-
tizer tician izer
Every action that would modify your code, config, or run a training process asks permission first โ agentlite's permission system is first-class, not an afterthought.
See ARCHITECTURE.md for the full design.
Project context
Each mlcompass project keeps a small folder, similar in spirit to
.git/:
.mlcompass/
โโโ project.yaml # metadata
โโโ context.json # decisions, recommendations, active state
โโโ datasets/ # registered datasets
โโโ runs/ # training run history (consumed by compare)
โโโ advice.log # JSONL of every command run
This is what makes mlcompass more than a chat tool: by the time you
run deploy, every earlier decision is still in memory.
Roadmap
| Phase | Commands | Status |
|---|---|---|
| Faz 1 (v0.1) | init, advise |
โ Shipped |
| Faz 2 (v0.2) | audit, watch, compare + --llm |
โ Shipped |
| Faz 2.2 (v0.3) | TensorBoard / W&B sources, --apply |
โ Shipped |
| Faz 3 (v0.3) | evaluate + leakage-smell warning |
โ Shipped |
| Faz 4 (v0.3) | deploy |
โ Shipped |
| Faz 5 (v0.3) | status |
โ Shipped |
| Faz 6 (v0.4) | MCP server โ mlcompass-mcp |
โ Shipped |
| Faz 7 (v0.5) | agent โ self-driving (api + claude-code backends) |
โ Shipped |
See CHANGELOG.md for the detailed log and ARCHITECTURE.md for the design.
Non-goals
To stay focused, mlcompass will not try to be:
- AutoML (use AutoGluon, AutoSklearn)
- Experiment tracker (use MLflow, W&B)
- Code assistant (use Cursor, Copilot, aider)
- Monitoring dashboard (use Grafana, Streamlit)
mlcompass advises; you decide.
Contributing
Alpha-stage โ issues and discussions welcome, see CONTRIBUTING.md for the dev setup.
License
MIT ยฉ 2026 Hakan Sabunis
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 mlcompass-0.5.0.tar.gz.
File metadata
- Download URL: mlcompass-0.5.0.tar.gz
- Upload date:
- Size: 138.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
36e8fba93ee1d306ead1c4f508b43652c5eb20641e7d057f248ddbacd8ab9ef5
|
|
| MD5 |
66b543348eb7af058d1ea36e8292250a
|
|
| BLAKE2b-256 |
34d7fe1ccd855aa3985a15642b2de9b3823eeb617cc6dfb51945bba7f5769486
|
File details
Details for the file mlcompass-0.5.0-py3-none-any.whl.
File metadata
- Download URL: mlcompass-0.5.0-py3-none-any.whl
- Upload date:
- Size: 110.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
05f952af9efa260bab2bdd81d415907979995daca2fcd4e7da8c09164dcc5fe7
|
|
| MD5 |
5b5099744c5da4003d42e2a9ad3c88be
|
|
| BLAKE2b-256 |
1167b18d10317286ded79cfc73cd73473de500870ab01bcd2a9aa51643729e3c
|