Skip to main content

Robot Control with LeRobot Integration for Strands Agents

Project description

Strands Robots

Robot control for Strands Agents.

Install

pip install strands-robots

Quick Start

from strands import Agent
from strands_robots import Robot, gr00t_inference

# Create robot with cameras
robot = Robot(
    tool_name="my_arm",
    robot="so101_follower",
    cameras={
        "front": {"type": "opencv", "index_or_path": "/dev/video0", "fps": 30},
        "wrist": {"type": "opencv", "index_or_path": "/dev/video2", "fps": 30}
    },
    port="/dev/ttyACM0",
    data_config="so100_dualcam"
)

# Create agent with robot tool
agent = Agent(tools=[robot, gr00t_inference])

# Start GR00T inference service
agent.tool.gr00t_inference(
    action="start",
    checkpoint_path="/path/to/checkpoint",
    port=8000,
    data_config="so100_dualcam"
)

# Control robot with natural language
agent("Use my_arm to pick up the red block using GR00T policy on port 8000")

# Cleanup
agent.tool.gr00t_inference(action="stop", port=8000)

Features

  • Robot Support - LeRobot integration (SO-100/101, Fourier GR-1, Unitree G1, Panda)
  • Policy Abstraction - Clean interface for any VLA provider (GR00T, ACT, etc.)
  • Multi-Camera - OpenCV and RealSense support with batch capture
  • Serial Communication - Feetech servo control and monitoring
  • Strands Tools - Camera, inference service, and serial tools included

Architecture

strands-robots/
├── robot.py              # Universal Robot class
├── policies/             # Policy abstraction
│   ├── __init__.py       # Policy base + factory
│   └── groot/            # GR00T implementation
│       ├── client.py     # ZMQ client
│       └── data_config.py # 6 embodiment configs
└── tools/                # Strands tools
    ├── gr00t_inference.py  # Docker service manager
    ├── lerobot_camera.py   # Camera operations
    └── serial_tool.py      # Serial communication

Supported Robots

  • SO-100/SO-101 - Single camera or dual camera modes
  • Fourier GR-1 - Bimanual humanoid arms
  • Unitree G1 - Humanoid robot platform
  • Bimanual Panda - Dual Franka Emika arms
  • Any LeRobot-compatible robot

Policy Providers

from strands_robots import create_policy

# GR00T policy
policy = create_policy(
    provider="groot",
    data_config="so100_dualcam",
    host="localhost",
    port=8000
)

# Mock policy (testing)
policy = create_policy(provider="mock")

Camera Tool

# Discover cameras
agent.tool.lerobot_camera(action="discover")

# Capture single image
agent.tool.lerobot_camera(
    action="capture",
    camera_id="/dev/video0",
    save_path="./captures"
)

# Batch capture from multiple cameras
agent.tool.lerobot_camera(
    action="capture_batch",
    camera_ids=["/dev/video0", "/dev/video2"],
    async_mode=True
)

# Record video
agent.tool.lerobot_camera(
    action="record",
    camera_id="/dev/video0",
    capture_duration=10.0
)

GR00T Inference Service

# Start service
agent.tool.gr00t_inference(
    action="start",
    checkpoint_path="/data/checkpoints/model",
    port=8000,
    data_config="so100_dualcam",
    denoising_steps=4
)

# Check status
agent.tool.gr00t_inference(action="status", port=8000)

# List all services
agent.tool.gr00t_inference(action="list")

# Stop service
agent.tool.gr00t_inference(action="stop", port=8000)

Serial Communication

# List available ports
agent.tool.serial_tool(action="list_ports")

# Control Feetech servo position
agent.tool.serial_tool(
    action="feetech_position",
    port="/dev/ttyACM0",
    motor_id=1,
    position=2048  # Center position
)

# Monitor serial data
agent.tool.serial_tool(
    action="monitor",
    port="/dev/ttyACM0",
    baudrate=1000000
)

Custom Robot Configuration

from lerobot.robots.config import RobotConfig

# Use LeRobot config directly
config = RobotConfig(...)
robot = Robot(tool_name="custom", robot=config)

# Or pass LeRobot Robot instance
from lerobot.robots.robot import Robot as LeRobotRobot
lerobot_instance = LeRobotRobot(...)
robot = Robot(tool_name="custom", robot=lerobot_instance)

Data Configs

Available GR00T data configurations:

  • so100 - Single camera SO-100
  • so100_dualcam - Dual camera SO-100 (front + wrist)
  • so100_4cam - Quad camera SO-100
  • fourier_gr1_arms_only - Fourier GR-1 arms
  • bimanual_panda_gripper - Bimanual Panda
  • unitree_g1 - Unitree G1 humanoid

License

Apache-2.0

Links

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

strands_robots-0.3.1.tar.gz (33.7 kB view details)

Uploaded Source

Built Distribution

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

strands_robots-0.3.1-py3-none-any.whl (35.4 kB view details)

Uploaded Python 3

File details

Details for the file strands_robots-0.3.1.tar.gz.

File metadata

  • Download URL: strands_robots-0.3.1.tar.gz
  • Upload date:
  • Size: 33.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.13

File hashes

Hashes for strands_robots-0.3.1.tar.gz
Algorithm Hash digest
SHA256 c2b31022e830279514581a73ef467a065aadb9e2e017b141f683dbb7725d93ea
MD5 6d5e7d62bf3d70ce2eb2737a58939833
BLAKE2b-256 5da923494ff85b2211869deeba67ebeba134b548326cbea73dc366ef8272480b

See more details on using hashes here.

File details

Details for the file strands_robots-0.3.1-py3-none-any.whl.

File metadata

  • Download URL: strands_robots-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 35.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.13

File hashes

Hashes for strands_robots-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 3c4e4529287db0cedb14f12c9bf11f0d551e062d328cb6d6891bbf7da052d6ac
MD5 fc91446a9d4fc6a80688a3c573e4acb0
BLAKE2b-256 e2a02a9f0f977e21f72384984d7a3f6d2f1948ed0b3d7ca451ba74abe5887a20

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