Skip to main content

Formula 1 analytics MCP server with 118+ tools powered by FastF1 and Ergast

Project description

F1 Analytics MCP Server

License: MIT Python 3.12+ Tests PyPI version GitHub stars GitHub issues GitHub Discussions

An MCP (Model Context Protocol) server providing 118+ Formula 1 analytics tools powered by FastF1 and the Ergast API. Connect it to Claude Desktop, Claude Code, or any MCP client to analyze races, compare drivers, explore telemetry, and simulate strategies using natural language.

Features

  • Session & Driver Info — race results, standings, circuit details, driver metadata
  • Lap & Sector Analysis — lap times, sector deltas, consistency scores, clean lap filtering
  • Telemetry — speed/throttle/brake/gear/RPM traces, corner analysis, braking points
  • Strategy Intelligence — tyre degradation, pit windows, undercut/overcut analysis, strategy simulation
  • Race Position — overtakes, battles, gap evolution, position changes, lead changes
  • Predictive AI — race winner prediction, overtake probability, tyre cliff prediction, safety car probability
  • Visualizations — speed maps, race progression charts, tyre degradation plots, track dominance maps

Quick Start

pip install (recommended)

pip install f1-mcp

Install from source:

pip install git+https://github.com/Luffy610/f1-mcp.git

Docker

docker compose up -d

The MCP server will be available at http://localhost:8000/sse.

MCP Client Configuration

Claude Desktop / Claude Code (stdio — recommended)

{
  "mcpServers": {
    "f1": {
      "command": "f1-mcp"
    }
  }
}

SSE mode (remote / Docker)

{
  "mcpServers": {
    "f1": {
      "type": "sse",
      "url": "http://localhost:8000/sse"
    }
  }
}

To start the SSE server manually: python server.py

Tool Categories

Category Tools Examples
Session 8 Race info, weather, circuit details, flag events
Driver 8 Standings, driver info, team lookup, points
Lap 10 Lap times, distributions, clean laps, deleted laps
Sector 8 Sector times, deltas, consistency, improvement trends
Telemetry 12 Speed/brake/throttle/gear traces, corner analysis
Strategy 10 Tyre strategy, stint lengths, compound usage, degradation
Pit Stops 6 Pit times, pit lane loss, pit stop summaries
Race Position 8 Overtakes, battles, gap evolution, lead changes
Strategy Intelligence 10 Undercut/overcut, optimal pit window, strategy simulation
Telemetry Intelligence 10 Braking analysis, corner speeds, dirty air, energy deployment
Advanced Analytics 8 Driver style clustering, aggression/risk indices, consistency
Predictive AI 14 Race winner, overtake probability, tyre cliff, safety car
Visualization 6 Speed maps, race progression, tyre degradation plots

Example Prompts

Analyze why Verstappen won the 2023 Bahrain GP. Break down his tyre strategy,
pit stops, race pace trend, and any overtakes he made.
Compare Verstappen and Leclerc through Turn 10 at the 2023 Bahrain GP.
Who brakes later, carries more apex speed, and gets on the throttle earlier?
Simulate how the 2023 Bahrain GP would have played out if Verstappen used
a two-stop strategy instead of his actual strategy.

See example.md for more detailed example prompts with the specific tools they trigger.

Contributing

We welcome contributions! The master branch is protected — please fork the repo, create a feature branch, and submit a pull request.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/my-new-tool)
  3. Make your changes and ensure tests pass (python -m pytest tests/ -v)
  4. Submit a pull request

See CONTRIBUTING.md for detailed guidelines on project structure, adding tools, and code style.

Reporting Issues & Requesting Features

Development

# Install in editable mode with dev dependencies
pip install -e ".[dev]"

# Run all tests
python -m pytest tests/ -v

# Run specific test group
python -m pytest tests/ -v -k "test_lap"

# Start SSE server for development
python server.py

Architecture

f1_mcp/                → Python package
  server.py            → Entry point, registers all tool modules
  config.py            → FastF1 cache configuration
  connectors/          → Data sources (FastF1Loader, ErgastClient)
  core/                → Caching layer + serialization utilities
  models/              → Pydantic schemas
  services/            → Business logic (14 service classes)
  tools/               → MCP tool registrations (14 modules, 1:1 with services)
tests/                 → End-to-end test suite (118 tests)

Environment Variables

Variable Default Description
F1_CACHE_DIR ./cache Directory for FastF1 data cache

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mcp_f1-0.1.1.tar.gz (36.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_f1-0.1.1-py3-none-any.whl (44.2 kB view details)

Uploaded Python 3

File details

Details for the file mcp_f1-0.1.1.tar.gz.

File metadata

  • Download URL: mcp_f1-0.1.1.tar.gz
  • Upload date:
  • Size: 36.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mcp_f1-0.1.1.tar.gz
Algorithm Hash digest
SHA256 a30fe00e345d604f7762e7e126fb68dfc4b66f84e071d16cdec477f5414eae8a
MD5 11ebd33f2f0316216df4c345390c7ee6
BLAKE2b-256 e6a1312681122f7c5d2781aed64ff2050b70c121094d34fc3bad8deb2aca2741

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_f1-0.1.1.tar.gz:

Publisher: publish.yml on Luffy610/f1-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mcp_f1-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: mcp_f1-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 44.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mcp_f1-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 873f7f0c31875f24d5c247139b1bdaa5e12ad5c81c831952c1c81d432ea7fbc3
MD5 94218dd96d511bf08039196a9d1042dd
BLAKE2b-256 9b5e9d59bde241f8c4e43eb10012d5e0124abed300dd739b34fbbd1d4fbaf47f

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_f1-0.1.1-py3-none-any.whl:

Publisher: publish.yml on Luffy610/f1-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page