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.0.tar.gz (36.4 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.0-py3-none-any.whl (43.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: mcp_f1-0.1.0.tar.gz
  • Upload date:
  • Size: 36.4 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.0.tar.gz
Algorithm Hash digest
SHA256 c20e7b96e3d6cadb4e7e8be329d88a63c345c707ef47764d9f7e4cb07a5a5715
MD5 b18d5ce4c21821a6fb8e16739cd7db6b
BLAKE2b-256 deccfe548e82a2aec545086e3967797ddc47ddee0828f8de7f00dd110346af26

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_f1-0.1.0.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.0-py3-none-any.whl.

File metadata

  • Download URL: mcp_f1-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 43.9 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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 60c86c32781c91ab1027c07e64528dad5588f35e573ebaf48ee779af3fe1978a
MD5 32999a3790add4dccded32e597b7a013
BLAKE2b-256 ea772ba9e91542b3f8aaa2b0ba0c796f835b20038f32bd9696f157e2071e65c6

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_f1-0.1.0-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