VectorClaw
Enables AI assistants to control Anki Vector robots locally via natural language, providing tools for speech, motion, perception, and interaction without cloud dependency.
README
๐ค VectorClaw
<div align="center">
Give your AI assistant a body.
VectorClaw is an MCP server that exposes Anki Vector robot capabilities as tools for AI assistants like OpenClaw โ bridging natural language to real-world robot actions over a fully local, cloud-free stack.
</div>
Architecture
โโโโโโโโโโโโโโโ stdio MCP โโโโโโโโโโโโโโโโโโโโ gRPC/WiFi โโโโโโโโโโโ
โ AI Agent โ โโโโโโโโโโโโโโโ โ vectorclaw-mcp โ โโโโโโโโโโโโโโโ โ Vector โ
โ (OpenClaw) โ โ (Python 3.11+) โ โ Robot โ
โโโโโโโโโโโโโโโ โโโโโโโโโโโโโโโโโโโโ โโโโโโโโโโโ
All communication is local-only โ no cloud dependency at runtime (Wire-Pod setup path).
See Security Architecture for the full trust model.
Table of Contents
- Architecture
- Current Status
- Quickstart
- MCP Client Configuration
- Available Tools
- Contributing
- Docs Map
Current Status
v1.0.0 Released ยท 2026-03-01
16 tools verified โ on hardware | 7 tools experimental โ ๏ธ
Known limitations:
vector_drive_on_chargerโ activates cube but no reliable charger approach- Perception detections โ often returns empty lists; SDK semantics under investigation
- Idle behaviors โ Vector's autonomous animations can overlap with commanded behaviors
See ROADMAP.md for the full milestone plan.
Quickstart
Requirements: Python 3.11+ ยท Wire-Pod running ยท Vector on local WiFi
For the complete walkthrough (Wire-Pod install, robot auth, WiFi config, troubleshooting) see docs/SETUP.md.
Guided Setup (recommended for new users)
The vectorclaw-setup wizard handles configuration, SDK validation, connectivity
check, and a smoke test in one go:
pip install vectorclaw-mcp
vectorclaw-setup
You will be prompted for your robot's serial number and optional IP address. On success you'll see a clear SETUP PASSED message and the next-steps command. On failure every step includes an exact remediation hint.
See docs/OPENCLAW_SETUP_SKILL.md for full details.
Manual Setup
Step 1 โ Install VectorClaw
pip install vectorclaw-mcp
Step 2 โ Configure Vector SDK
Wire-Pod is the canonical self-hosted server for Vector. Install the SDK distribution and run the one-time auth wizard:
pip install wirepod_vector_sdk
python -m anki_vector.configure
Note:
wirepod_vector_sdkinstalls under theanki_vectorPython namespace, so all imports and CLI commands useanki_vector.
<details> <summary>Legacy cloud path (best-effort only)</summary>
The standalone anki_vector package requires working DDL cloud servers and is brittle on modern Python runtimes.
pip install "vectorclaw-mcp[legacy]"
python -m anki_vector.configure
Prefer wirepod_vector_sdk for reliable, cloud-independent operation.
</details>
Step 3 โ Set environment variables
export VECTOR_SERIAL="your-robot-serial" # required โ printed on underside of robot
export VECTOR_HOST="192.168.x.x" # optional โ auto-discovered if omitted
Step 4 โ Run the server
vectorclaw-mcp
# or
python -m vectorclaw_mcp
MCP Client Configuration
Add the following block to your mcporter.json (or equivalent MCP client config).
With uvx (recommended โ no prior install needed)
{
"mcpServers": {
"vectorclaw": {
"command": "uvx",
"args": ["vectorclaw-mcp"],
"env": {
"VECTOR_SERIAL": "your-serial-here"
}
}
}
}
With pip install (if installed locally)
{
"mcpServers": {
"vectorclaw": {
"command": "vectorclaw-mcp",
"env": {
"VECTOR_SERIAL": "your-serial-here"
}
}
}
}
Available Tools
| Tool | Category | Description | Status |
|---|---|---|---|
vector_say |
๐๏ธ Speech | Make the robot speak text aloud | โ |
vector_animate |
๐ญ Expression | Play a named animation | โ ๏ธ |
vector_drive_off_charger |
๐๏ธ Motion | Drive the robot off its charger | โ |
vector_drive |
๐๏ธ Motion | Drive straight and/or turn in place | โ |
vector_drive_on_charger |
๐๏ธ Motion | Drive Vector back onto its charger | โ ๏ธ |
vector_emergency_stop |
๐๏ธ Motion | Stop all motion immediately | โ |
vector_head |
๐ฆพ Actuation | Set head angle (โ22ยฐ โ 45ยฐ) | โ |
vector_lift |
๐ฆพ Actuation | Set lift height (0.0 โ 1.0) | โ |
vector_look |
๐ Perception | Capture image from front camera | โ |
vector_capture_image |
๐ Perception | One-shot image capture | โ |
vector_face |
๐ผ๏ธ Display | Display custom image on face screen | โ |
vector_scan |
๐ Perception | Head scan for environment | โ |
vector_find_faces |
๐ Perception | Scan for faces | โ ๏ธ |
vector_list_visible_faces |
๐ Perception | List currently visible faces | โ ๏ธ |
vector_face_detection |
๐ Perception | Get face detection summary | โ ๏ธ |
vector_list_visible_objects |
๐ Perception | List currently visible objects | โ ๏ธ |
vector_cube |
๐ฒ Interaction | Interact with cube (dock/pickup/drop/roll) | โ ๏ธ |
vector_vision_reset |
๐ Perception | Disable all vision modes | โ |
vector_pose |
๐ Sensing | Get current position and orientation | โ |
vector_status |
๐ Status | Get battery level and charging status | โ |
vector_charger_status |
๐ Status | Get charger connection state | โ |
vector_touch_status |
๐ Status | Get touch sensor state | โ |
vector_proximity_status |
๐ Status | Get proximity sensor reading | โ |
Status legend: โ Verified on hardware | โ ๏ธ Experimental (limited/reliable issues)
โ ๏ธ Charger prerequisite:
vector_driverequires the robot to be off the charger. Callvector_drive_off_chargerfirst, or setVECTOR_AUTO_DRIVE_OFF_CHARGER=1for automatic undocking.
See docs/MCP_API_REFERENCE.md for full parameter details and response schemas.
Contributing
- ๐ฟ Branch: branch off
dev, use<type>/<short-description>naming (e.g.fix/vector-face-payload,feat/vector-scan) - ๐งช Tests: add or update tests under
tests/; all tests use the mocked SDK โ no hardware required - โ
CI: Python 3.11 is required and must pass; Python 3.12 is experimental/informational โ run
pytest tests/ -vlocally before opening a PR - ๐ค Hardware: if your change touches a tool or connection layer, record a smoke-test run in Hardware Smoke Log following the Hardware Test Playbook
- ๐ฏ PR scope: keep PRs focused โ separate docs, feature, and refactor changes to reduce merge-conflict risk with parallel lanes
Docs Map
๐ ๏ธ Setup & Runtime
| Document | Description |
|---|---|
| Setup Guide | Wire-Pod install, robot auth, WiFi, SDK config, troubleshooting |
| Troubleshooting | Common runtime failures, smoke baseline, and escalation path |
| Runtime Support | Supported Python versions and CI policy |
๐ก API & SDK
| Document | Description |
|---|---|
| API Reference | MCP tool signatures, parameters, response schemas |
| Wire-Pod SDK Reference | Full SDK capability catalog |
| Wire-Pod SDK โ MCP Integration Priorities | Now/Later/Skip decision table for future tools |
๐ฌ Hardware Validation
| Document | Description |
|---|---|
| Hardware Test Playbook | Repeatable on-robot validation protocol and PR checklist |
| Hardware Smoke Log | Running record of real-world smoke tests |
| Tool Docking Prerequisites | Which tools require undocked state |
๐ Security
| Document | Description |
|---|---|
| Security Architecture | Threat model, credential handling, input validation, network posture |
License
MIT โ see LICENSE.
<!-- If you found this: yes, premium natural oil is appreciated. -->
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.