Benchmark suite and community leaderboard for local LLM inference on Apple Silicon
Project description
mlx-Chronos ⏱️
Benchmark suite and community leaderboard for local LLM inference on Apple Silicon.
Run it. Share your results. Compare across hardware.
What is mlx-Chronos?
mlx-Chronos is a standardized benchmarking tool for local LLM inference engines on Apple Silicon. It automatically detects your hardware, runs a consistent set of tests across installed engines, and produces a structured JSON result you can contribute to the community leaderboard.
Supported engines:
- Ollama (MLX backend)
- oMLX
- Rapid-MLX
- mlx-lm (Apple MLX)
Metrics measured:
- TTFT — Time to First Token (cold and cached, with statistics)
- tok/s — Generation throughput (mean, stddev, min, max across trials)
- Engine RSS — Peak RSS of the engine server process during the benchmark when available
- System RAM peak — Peak total Mac RAM in use during the benchmark
- Tool calling — Success rate (coming in v0.2)
How It Works
When you run mlx-Chronos, it executes a fixed benchmark protocol against the running engine:
Cold TTFT — sends a prompt to the model and measures the time from request to first non-empty streamed token, including whitespace-only text tokens. Each trial uses a unique prompt to avoid cache hits.
Cached TTFT — sends the same fixed prompt on every cached trial. A priming call loads it into cache first, then cached trials run consecutively. This measures cache performance without interleaving unrelated prompts between cached measurements.
Throughput (tok/s) — measures tokens generated per second using a standard fixed prompt, identical across all engines and versions.
Peak engine RSS — measures the resident memory of the engine server process
after warmup, through the recorded benchmark phases. This is
intentionally not the total memory occupied by the loaded model or by
macOS/Metal unified memory. It is meant to compare how light or heavy each
engine process is while serving the same model. The default RSS sampling
interval is 50ms and can be changed with --ram-sample-interval.
System RAM peak — continuously samples total Mac RAM usage from before warmup through the recorded benchmark phases and reports the observed peak in GB and percent. This is the metric to use when checking whether a run pushed the machine into memory pressure or swap while the model was actually loading or serving requests.
All metrics are run over multiple trials and reported with mean, stddev, min,
and max. The default is 5 trials, with a maximum of 8 unique cold prompts.
Results are saved as structured JSON in results/local/ by default. Copy a
reviewed JSON into results/submitted/ only when you want to publish it to the
community leaderboard.
Community Leaderboard
View the full leaderboard with all submitted results:
→ igurss.github.io/mlx-chronos
Quick Start
# Install
pip install mlx-chronos
# Check available engines
mlx-chronos engines
# Validate setup before a run
mlx-chronos validate --engine omlx --model "Qwen3.5-4B-OptiQ-4bit"
# Run benchmark (JSON by default)
mlx-chronos run --engine omlx --model "Qwen3.5-4B-OptiQ-4bit"
# Optional: write both JSON and Markdown outputs
mlx-chronos run --engine omlx --model "Qwen3.5-4B-OptiQ-4bit" --format all
# Optional: choose a custom output directory
mlx-chronos run --engine omlx --model "Qwen3.5-4B-OptiQ-4bit" --output-dir ~/Desktop/benchmarks
Note: the engine server must be running before you launch mlx-chronos. See CONTRIBUTING.md for setup instructions.
Contributing Your Results
- Run
mlx-chronos runon your Mac - A JSON file is generated in
results/local/(use--format allfor a Markdown summary too) - Fork this repo and copy the JSON you want to publish into
results/submitted/ - GitHub Actions validates your result automatically
- Once merged, the leaderboard updates
Leaderboard submissions must report throughput using the engine response's
usage.completion_tokens. Local runs can still be saved with a fallback token
estimate, but those results are not accepted for the public leaderboard.
See CONTRIBUTING.md for detailed instructions.
Benchmark Methodology
See docs/methodology.md for a full explanation of what is measured, how, and why.
Roadmap
Completed
- Core benchmark runner with repeated trials, warmup, cache priming, and phase-separated metrics
- Engine support for oMLX, Rapid-MLX, mlx-lm, and Ollama
- Hardware detection for chip, machine model, memory, macOS, Python, architecture, and thermal state
- Strict JSON schema validation with raw-trial consistency checks
- Continuous engine RSS and system RAM peak sampling
- Preflight validation for engine, server, and model access
- GitHub Actions validation for submitted results
- GitHub Pages leaderboard with engine/chip filters
- JSON and Markdown result export
- Published Apple M2 sample results refreshed with the current benchmark protocol
Next
- Add
mlx-chronos submitto help prepare leaderboard submissions - Add warnings for battery mode, low power mode, and non-nominal thermal state
- Improve leaderboard filtering by machine model and add broader column tooltips
- Add integration tests against mock OpenAI-compatible servers
Future
- Support larger trial counts with a bigger cold-prompt pool
- Add p95 reporting for larger sample sizes
- Evaluate a clearer TTFT naming model without breaking the v0.1 JSON contract
- Add tool-calling success-rate benchmarks
- Explore anti-spoofing checks for community submissions
- Document external contributor branch workflow when community PRs start arriving
- Collect more results from M3, M4, and M5 systems
License
Apache 2.0 — see LICENSE
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 mlx_chronos-0.1.0.tar.gz.
File metadata
- Download URL: mlx_chronos-0.1.0.tar.gz
- Upload date:
- Size: 33.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
502645697d567c396bc22677fec78649f3dd461dd9145dbdea8a5f60a13f13b4
|
|
| MD5 |
6590cdd530c3468e47d09046ab726d6a
|
|
| BLAKE2b-256 |
9ea24546d883c997fa4eaa7fb2ba1a5de2176c4f8af2e19de82e8f05ffa92957
|
Provenance
The following attestation bundles were made for mlx_chronos-0.1.0.tar.gz:
Publisher:
release.yml on igurss/mlx-chronos
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mlx_chronos-0.1.0.tar.gz -
Subject digest:
502645697d567c396bc22677fec78649f3dd461dd9145dbdea8a5f60a13f13b4 - Sigstore transparency entry: 1671385948
- Sigstore integration time:
-
Permalink:
igurss/mlx-chronos@97ee058f2558f5e37d12d833d01addd23892b59a -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/igurss
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@97ee058f2558f5e37d12d833d01addd23892b59a -
Trigger Event:
push
-
Statement type:
File details
Details for the file mlx_chronos-0.1.0-py3-none-any.whl.
File metadata
- Download URL: mlx_chronos-0.1.0-py3-none-any.whl
- Upload date:
- Size: 27.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
561f72d49a642f843f79aac99792009eb746a780af99297e107b717f531a4d40
|
|
| MD5 |
067a2c2b5b2affd9f92649f0f8e54e7d
|
|
| BLAKE2b-256 |
e5ae6a18637061b48f5100cd454235d7d7d0e0e80b574b1c967199ef010a40a3
|
Provenance
The following attestation bundles were made for mlx_chronos-0.1.0-py3-none-any.whl:
Publisher:
release.yml on igurss/mlx-chronos
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mlx_chronos-0.1.0-py3-none-any.whl -
Subject digest:
561f72d49a642f843f79aac99792009eb746a780af99297e107b717f531a4d40 - Sigstore transparency entry: 1671386014
- Sigstore integration time:
-
Permalink:
igurss/mlx-chronos@97ee058f2558f5e37d12d833d01addd23892b59a -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/igurss
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@97ee058f2558f5e37d12d833d01addd23892b59a -
Trigger Event:
push
-
Statement type: