Skip to main content

MCP server exposing FiftyOne dataset analysis tools

Project description

FiftyOne MCP Server

 

Control FiftyOne datasets through AI assistants using the Model Context Protocol

License PyPI Python

Discord Hugging Face Voxel51 Blog Newsletter LinkedIn Twitter Medium

Documentation · FiftyOne Skills · FiftyOne Plugins · Discord

What is the FiftyOne MCP Server?

Enable Agents to explore datasets, execute operators, and control the FiftyOne App through natural language. This server exposes 45+ MCP tools across data operations, App UI control, and the full operator/plugin ecosystem.

"List all my datasets"
"Load quickstart dataset and show summary"
"Find similar images in my dataset"

The server starts with 50 built-in operators. Install plugins to expand functionality - the AI can discover and install plugins automatically when needed (brain, zoo, annotation, evaluation, and more).

Available Tools

Category Tools Description
📊 Dataset Management 3 List, load, and summarize datasets
🎯 App Operations 29 Control the App UI (views, panels, selection, ...)
Operator System 3 Discover and execute any FiftyOne operator
🔄 Pipelines 2 Run pipelines and manage delegated operations
🔌 Plugin Management 5 Discover, install, and manage plugins
🖥️ Session 1 Launch the FiftyOne App server
📈 Aggregations 8 Count, distinct, bounds, mean, histogram, ...
🧬 Samples 5 Add, tag, untag, and set values on samples
🗂️ Schema 2 Inspect and modify dataset field schemas
🎨 App Config 6 Color scheme, sidebar groups, active fields

Tool modes

45+ tools organized by runtime mode:

  • SDK: Data operations that work everywhere (datasets, aggregations, schema, samples, operators, plugins). No App connection needed.
  • APP: Controls the FiftyOne App UI in real time (set_view, open_panel, notify, select_samples, reload, and 25+ more). Requires a connected browser via ctx.ops.
  • SESSION: Bootstrap tools for starting a local App server (launch_app). Used from terminal environments.

Choosing your tools

Which tools are available depends on how you integrate the server:

Integration Modes Use case
FiftyOne App plugin app + sdk Agent panel inside the App (full UI control + data operations)
Terminal / CLI session + sdk Headless agent (launch the App, query data, execute operators)

Tool risk levels

Every tool is tagged with a risk level that your agent can use for auto-approval decisions:

  • LOW Safe to auto-execute without prompting (read-only queries, UI state changes)
  • OPERATOR Wraps a FiftyOne operator whose own severity should be checked before executing

Quick Start

Step 1: Install the MCP Server

pip install fiftyone-mcp-server

⚠️ Important: Make sure to use the same Python environment where you installed the MCP server when configuring your AI tool. If you installed it in a virtual environment or conda environment, you must activate that environment or specify the full path to the executable.

Step 2: Configure Your AI Tool

Claude Code (Recommended)
claude mcp add fiftyone -- fiftyone-mcp
Claude Desktop

Edit ~/Library/Application Support/Claude/claude_desktop_config.json:

{
  "mcpServers": {
    "fiftyone": {
      "command": "fiftyone-mcp"
    }
  }
}
Cursor

Install in Cursor

Add to ~/.cursor/mcp.json:

{
  "mcpServers": {
    "fiftyone": {
      "command": "fiftyone-mcp"
    }
  }
}
VSCode

Install in VS Code

Add to .vscode/mcp.json:

{
  "servers": {
    "fiftyone": {
      "command": "fiftyone-mcp"
    }
  }
}
ChatGPT Desktop

Edit ~/Library/Application Support/ChatGPT/config.json:

{
  "mcpServers": {
    "fiftyone": {
      "command": "fiftyone-mcp"
    }
  }
}
uvx (No Install Needed)

If you have uv installed:

{
  "mcpServers": {
    "fiftyone": {
      "command": "uvx",
      "args": ["fiftyone-mcp-server"]
    }
  }
}

This downloads and runs the latest version automatically.

Step 3: Use It

"List all my datasets"
"Load quickstart dataset and show summary"
"Open the map panel and show me the embeddings"
"Select samples with confidence above 0.9"
"What plugins are available? Install the brain plugin"
"Find near-duplicate images in my dataset"

Claude will automatically discover operators and execute the appropriate tools.

Contributing

We welcome contributions! Here's how to set up a local development environment:

  1. Clone the repository

    git clone https://github.com/voxel51/fiftyone-mcp-server.git
    cd fiftyone-mcp-server
    
  2. Install dependencies

    poetry install
    
  3. Run the server locally

    poetry run fiftyone-mcp
    
  4. Test your changes

    poetry run pytest
    poetry run black -l 79 src/
    npx @modelcontextprotocol/inspector poetry run fiftyone-mcp
    
  5. Submit a Pull Request

Resources

Resource Description
FiftyOne Docs Official documentation
FiftyOne Skills Expert workflows for AI assistants
FiftyOne Plugins Official plugin collection
Model Context Protocol MCP specification
PyPI Package MCP server on PyPI
Discord Community Get help and share ideas

Community

Join the FiftyOne community to get help, share your ideas, and connect with other users:


Copyright 2017-2026, Voxel51, Inc. · Apache 2.0 License

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

fiftyone_mcp_server-0.1.10.tar.gz (35.3 kB view details)

Uploaded Source

Built Distribution

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

fiftyone_mcp_server-0.1.10-py3-none-any.whl (44.3 kB view details)

Uploaded Python 3

File details

Details for the file fiftyone_mcp_server-0.1.10.tar.gz.

File metadata

  • Download URL: fiftyone_mcp_server-0.1.10.tar.gz
  • Upload date:
  • Size: 35.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.14.0 Darwin/25.1.0

File hashes

Hashes for fiftyone_mcp_server-0.1.10.tar.gz
Algorithm Hash digest
SHA256 bb05517fdbdba7e36aa16615137aaf6cb07273318a883bd0d945ea3d1d59736c
MD5 4bf3feebbddbe981608bbc84274189e4
BLAKE2b-256 e87d5cccde43e5fd0558e27bf3b0611719299316c7ce898489860b6b327d03cf

See more details on using hashes here.

File details

Details for the file fiftyone_mcp_server-0.1.10-py3-none-any.whl.

File metadata

File hashes

Hashes for fiftyone_mcp_server-0.1.10-py3-none-any.whl
Algorithm Hash digest
SHA256 bd80b10816b0ba6f75cc7a5a3c5549b5e9ef17c2f47858760dcc8e8f0e45628d
MD5 05f68149fabd7812d8299cb814e4a575
BLAKE2b-256 5dba42fbae9f4beac845be87b7f0a5cdbac73d6c1e7ed75d664088b34b9bf08c

See more details on using hashes here.

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