MCP server exposing FiftyOne dataset analysis tools
Project description
FiftyOne MCP Server
Control FiftyOne datasets through AI assistants using the Model Context Protocol
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:
LOWSafe to auto-execute without prompting (read-only queries, UI state changes)OPERATORWraps 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"
}
}
}
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:
-
Clone the repository
git clone https://github.com/voxel51/fiftyone-mcp-server.git cd fiftyone-mcp-server
-
Install dependencies
poetry install -
Run the server locally
poetry run fiftyone-mcp
-
Test your changes
poetry run pytest poetry run black -l 79 src/ npx @modelcontextprotocol/inspector poetry run fiftyone-mcp
-
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:
- Discord: FiftyOne Community
- GitHub Issues: Report bugs or request features
Copyright 2017-2026, Voxel51, Inc. · Apache 2.0 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 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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bb05517fdbdba7e36aa16615137aaf6cb07273318a883bd0d945ea3d1d59736c
|
|
| MD5 |
4bf3feebbddbe981608bbc84274189e4
|
|
| BLAKE2b-256 |
e87d5cccde43e5fd0558e27bf3b0611719299316c7ce898489860b6b327d03cf
|
File details
Details for the file fiftyone_mcp_server-0.1.10-py3-none-any.whl.
File metadata
- Download URL: fiftyone_mcp_server-0.1.10-py3-none-any.whl
- Upload date:
- Size: 44.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.14.0 Darwin/25.1.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bd80b10816b0ba6f75cc7a5a3c5549b5e9ef17c2f47858760dcc8e8f0e45628d
|
|
| MD5 |
05f68149fabd7812d8299cb814e4a575
|
|
| BLAKE2b-256 |
5dba42fbae9f4beac845be87b7f0a5cdbac73d6c1e7ed75d664088b34b9bf08c
|