Python SDK for Cyberwave
Project description
Cyberwave Python SDK
The official Python SDK for Cyberwave. Create, control, and simulate robotics with ease.
Installation
pip install cyberwave
Quick Start
1. Get Your Token
Get your API token from the Cyberwave platform:
- Log in to your Cyberwave instance
- Navigate to Profile → API Tokens
- Create a token and copy it
2. Create Your First Digital Twin
from cyberwave import Cyberwave
# Configure with your token
cw = Cyberwave(
token="your_token_here",
)
# Create a digital twin from an asset
robot = cw.twin("the-robot-studio/so101")
# Control position and rotation
robot.move(x=1.0, y=0.0, z=0.5)
robot.rotate(yaw=90) # degrees
# Move the robot arm to 30 degrees
robot.joints.set("1", 30)
# Get current joint positions
print(robot.joints.get_all())
Core Features
Working with Workspaces and Projects
from cyberwave import Cyberwave
cw = Cyberwave(
token="your_token_here"
)
# You can also set your token as an environment variable: export CYBERWAVE_TOKEN=your_token_here
# in that case, you can simply do:
cw = Cyberwave()
# List workspaces
workspaces = cw.workspaces.list()
print(f"Found {len(workspaces)} workspaces")
# Create a project
project = cw.projects.create(
name="My Robotics Project",
workspace_id=workspaces[0].uuid
)
# Create an environment
environment = cw.environments.create(
name="Development",
project_id=project.uuid
)
Managing Assets and Twins
# To instantiate a twin, you can query the available assets from the catalog.
# This query will return both the public assets availaable at cyberwave.com/catalog and the private assets available to your organization.
assets = cw.assets.search("so101")
robot = cw.twin(assets[0].registry_id) # the registry_id is the unique identifier for the asset in the catalog. in this case it's the-robot-studio/so101
# Move to a specific position
robot.move_to([1.0, 0.5, 0.0])
# Update scale
robot.scale(x=1.5, y=1.5, z=1.5)
# Move a joint to a specific position using radians
robot.joints.set("shoulder_joint", math.pi/4)
# You can also use degrees:
robot.joints.set("shoulder_joint", 45, degrees=True)
# You can also go a get_or_create for a specific twin an environment you created:
robot = cw.twin("the-robot-studio/so101", environment_id="YOUR_ENVIRONMENT_ID")
Environment Variables
If you are always using the same environment, you can set it as a default with the CYBERWAVE_ENVIRONMENT_ID environment variable:
export CYBERWAVE_ENVIRONMENT_ID="YOUR_ENVIRONMENT_ID"
export CYBERWAVE_TOKEN="YOUR_TOKEN"
python your_script.py
And then you can simply do:
from cyberwave import Cyberwave
cw = Cyberwave()
robot = cw.twin("the-robot-studio/so101")
This code will return you the first SO101 twin in your environment, or create it if it doesn't exist.
Video Streaming (WebRTC)
Stream camera feeds to your digital twins using WebRTC.
To stream you will need to install FFMPEG if you don't have it.
On Mac with brew:
brew install ffmpeg pkg-config
On Ubuntu:
sudo apt-get install ffmpeg
Then install the additional deps for camera streaming:
# Install with camera support
pip install cyberwave[camera]
import asyncio
from cyberwave import Cyberwave
# Initialize client
cw = Cyberwave()
# Create camera streamer - integrated into the Cyberwave client!
streamer = cw.video_stream(
twin_uuid="your_twin_uuid",
camera_id=0, # Default camera
fps=10 # Frames per second
)
# Start streaming
async def stream_camera():
await streamer.start()
# Stream runs until stopped
await asyncio.sleep(60) # Stream for 60 seconds
await streamer.stop()
# Run the async function
asyncio.run(stream_camera())
The video_stream() method:
- Automatically uses the client's MQTT connection
- Pre-configures the streamer with the twin UUID
- Handles WebRTC peer connection setup
- Manages ICE candidate gathering with STUN/TURN servers
- Handles video encoding and streaming
Advanced Usage
Joint Control
You can change a specific joint actuation. You can use degrees or radiants:
robot = cw.twin("the-robot-studio/so101")
# Set individual joints (degrees by default)
robot.joints.set("shoulder_joint", 45, degrees=True)
# Or use radians
import math
robot.joints.set("elbow_joint", math.pi/4, degrees=False)
# Get current joint position
angle = robot.joints.get("shoulder_joint")
# List all joints
joint_names = robot.joints.list()
# Get all joint states at once
all_joints = robot.joints.get_all()
API Reference
You can use the lower level API by using the client attribute:
from cyberwave import Cyberwave
cw = Cyberwave()
client = cw.client.rest # for the rest API
client = cw.client.mqtt # for the MQTT API
To check out the available endpoints and their parameters, you can refer to the full API reference here.
Examples
Check the examples directory for complete examples:
- Basic twin control
- Multi-robot coordination
- Real-time synchronization
- Joint manipulation for robot arms
Testing
Unit Tests
Run basic import tests:
poetry install
poetry run python tests/test_imports.py
Support
- Documentation: docs.cyberwave.com
- Issues: GitHub Issues
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 cyberwave-0.2.9.tar.gz.
File metadata
- Download URL: cyberwave-0.2.9.tar.gz
- Upload date:
- Size: 129.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.9.25 Linux/6.11.0-1018-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
55ae0043b596c67dc40c14ac7d38071b6e0dc70b522b9973acecf56eb7334368
|
|
| MD5 |
f6248d79486eb404990f3d16934246e2
|
|
| BLAKE2b-256 |
0dac44bb3c967d67f628fd74fbc62a5dae0ddcdcb981c178e5409118e5addad6
|
File details
Details for the file cyberwave-0.2.9-py3-none-any.whl.
File metadata
- Download URL: cyberwave-0.2.9-py3-none-any.whl
- Upload date:
- Size: 280.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.9.25 Linux/6.11.0-1018-azure
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fbc98672dc8e41fca5be2c9943677c845462db03b99a8eaf63a84e9e681045f1
|
|
| MD5 |
23cdc0ae735b0f79c3b497a0e82b3d86
|
|
| BLAKE2b-256 |
58378418d664f682b9bcfcfd8aa4add1823cb55517d8ca907ed1c729e6928034
|