Track ML Training Experiments and Alerts
Trackio logs ML training metrics and alerts, syncs to Hugging Face Spaces dashboards, and provides CLI/JSON retrieval for autonomous experiment iteration.
Why it matters
Automate the tracking and monitoring of machine learning training runs. Log metrics, fire diagnostic alerts, and visualize progress in real-time via Hugging Face Spaces.
Outcomes
What it gets done
Log training metrics using a Python API.
Define and trigger alerts for training diagnostics (INFO, WARN, ERROR).
Retrieve metrics and alerts via a command-line interface.
Sync experiment data to Hugging Face Spaces for remote monitoring.
Install
Add it to your toolbox
Run in your project directory:
curl -fsSL https://spark.entire.vc/get/ag-hugging-face-trackio | bash Capabilities
What this skill does
Traces errors to their root cause and suggests fixes.
Writes and executes SQL or NoSQL queries on databases.
Moves and transforms data between systems on a schedule.
Sends alerts or messages via email, Slack, or other channels.
Overview
Trackio - Experiment Tracking for ML Training
What it does
Trackio is an experiment tracking library for ML training that logs metrics, fires structured alerts, and syncs to Hugging Face Spaces for real-time dashboards. It provides a Python API for instrumentation and a CLI for programmatic retrieval with JSON output.
How it connects
Use Trackio when you need to log training metrics and diagnostic alerts during ML experiments, especially for autonomous workflows where an agent must poll alerts and metrics to decide whether to continue, stop, or adjust hyperparameters. Use it for remote/cloud training when you need metrics to persist in a Hugging Face Space dashboard after the instance terminates.
Source README
Trackio - Experiment Tracking for ML Training
Trackio is an experiment tracking library for logging and visualizing ML training metrics. It syncs to Hugging Face Spaces for real-time monitoring dashboards.
Three Interfaces
| Task | Interface | Reference |
|---|---|---|
| Logging metrics during training | Python API | references/logging_metrics.md |
| Firing alerts for training diagnostics | Python API | references/alerts.md |
| Retrieving metrics & alerts after/during training | CLI | references/retrieving_metrics.md |
When to Use Each
Python API → Logging
Use import trackio in your training scripts to log metrics:
- Initialize tracking with
trackio.init() - Log metrics with
trackio.log()or use TRL'sreport_to="trackio" - Finalize with
trackio.finish()
Key concept: For remote/cloud training, pass space_id - metrics sync to a Space dashboard so they persist after the instance terminates.
→ See references/logging_metrics.md for setup, TRL integration, and configuration options.
Python API → Alerts
Insert trackio.alert() calls in training code to flag important events - like inserting print statements for debugging, but structured and queryable:
trackio.alert(title="...", level=trackio.AlertLevel.WARN)- fire an alert- Three severity levels:
INFO,WARN,ERROR - Alerts are printed to terminal, stored in the database, shown in the dashboard, and optionally sent to webhooks (Slack/Discord)
Key concept for LLM agents: Alerts are the primary mechanism for autonomous experiment iteration. An agent should insert alerts into training code for diagnostic conditions (loss spikes, NaN gradients, low accuracy, training stalls). Since alerts are printed to the terminal, an agent that is watching the training script's output will see them automatically. For background or detached runs, the agent can poll via CLI instead.
→ See references/alerts.md for the full alerts API, webhook setup, and autonomous agent workflows.
CLI → Retrieving
Use the trackio command to query logged metrics and alerts:
trackio list projects/runs/metrics- discover what's availabletrackio get project/run/metric- retrieve summaries and valuestrackio list alerts --project <name> --json- retrieve alertstrackio show- launch the dashboardtrackio sync- sync to HF Space
Key concept: Add --json for programmatic output suitable for automation and LLM agents.
→ See references/retrieving_metrics.md for all commands, workflows, and JSON output formats.
Minimal Logging Setup
import trackio
trackio.init(project="my-project", space_id="username/trackio")
trackio.log({"loss": 0.1, "accuracy": 0.9})
trackio.log({"loss": 0.09, "accuracy": 0.91})
trackio.finish()
Minimal Retrieval
trackio list projects --json
trackio get metric --project my-project --run my-run --metric loss --json
Autonomous ML Experiment Workflow
When running experiments autonomously as an LLM agent, the recommended workflow is:
- Set up training with alerts - insert
trackio.alert()calls for diagnostic conditions - Launch training - run the script in the background
- Poll for alerts - use
trackio list alerts --project <name> --json --since <timestamp>to check for new alerts - Read metrics - use
trackio get metric ...to inspect specific values - Iterate - based on alerts and metrics, stop the run, adjust hyperparameters, and launch a new run
import trackio
trackio.init(project="my-project", config={"lr": 1e-4})
for step in range(num_steps):
loss = train_step()
trackio.log({"loss": loss, "step": step})
if step > 100 and loss > 5.0:
trackio.alert(
title="Loss divergence",
text=f"Loss {loss:.4f} still high after {step} steps",
level=trackio.AlertLevel.ERROR,
)
if step > 0 and abs(loss) < 1e-8:
trackio.alert(
title="Vanishing loss",
text="Loss near zero - possible gradient collapse",
level=trackio.AlertLevel.WARN,
)
trackio.finish()
Then poll from a separate terminal/process:
trackio list alerts --project my-project --json --since "2025-01-01T00:00:00"
Limitations
- Use this skill only when the task clearly matches the scope described above.
- Do not treat the output as a substitute for environment-specific validation, testing, or expert review.
- Stop and ask for clarification if required inputs, permissions, safety boundaries, or success criteria are missing.
Discussion
Questions & comments · 0
Sign In Sign in to leave a comment.