Python library for controlling BonicBot humanoid robot via serial communication and WebSocket
Project description
BonicBot Python Library
A comprehensive Python library for controlling BonicBot humanoid robots via serial communication or WebSocket. This library provides intuitive methods to control individual servos, coordinate complex movements, and manage the robot's base motors with support for both local (serial) and remote (WebSocket) connections.
Features
- Dual Communication Support: Serial (USB/UART) and WebSocket connectivity
- Individual Servo Control: Precise control of each servo with custom angles, speeds, and acceleration
- Group Control: Coordinated control of head, left hand, right hand, and base motors
- GUI Interface: User-friendly graphical interface for real-time robot control
- Preset Positions: Built-in preset positions and custom position saving/loading
- Robust Communication: Error handling and connection management for both protocols
- Type Hints: Full type annotations for better IDE support and code reliability
Installation
From PyPI (Recommended)
pip install bonicbot
# Test your installation
bonicbot-test
For GUI support
The GUI requires tkinter, which is not installable via pip. Install it through your system package manager:
# Install bonicbot first
pip install bonicbot
# Then install tkinter (system-dependent):
# Ubuntu/Debian:
sudo apt-get install python3-tk
# CentOS/RHEL:
sudo yum install python3-tkinter
# Fedora:
sudo dnf install python3-tkinter
# macOS (if missing):
brew install python-tk
# Windows: Usually included with Python
Development Installation
git clone https://github.com/yourusername/bonicbot.git
cd bonicbot
pip install -e .[dev]
Quick Start
Serial Communication (USB/UART)
from bonicbot import BonicBotController, create_serial_controller
# Method 1: Direct initialization
bot = BonicBotController('serial', port='/dev/ttyUSB0', baudrate=115200)
# Method 2: Using convenience function
bot = create_serial_controller('/dev/ttyUSB0') # Linux/Mac
# bot = create_serial_controller('COM3') # Windows
# Control individual servo
bot.control_servo('headPan', angle=45.0, speed=200)
# Control head movement
bot.control_head(pan_angle=30.0, tilt_angle=-10.0)
# Control left hand
bot.control_left_hand(gripper_angle=90.0, elbow_angle=45.0)
# Move the robot base
bot.move_forward(speed=100)
bot.turn_left(speed=50)
bot.stop()
# Close connection
bot.close()
WebSocket Communication (Remote/Network)
from bonicbot import BonicBotController, create_websocket_controller
# Method 1: Direct initialization
bot = BonicBotController('websocket', websocket_uri='ws://192.168.1.100:8080/control')
# Method 2: Using convenience function
bot = create_websocket_controller('ws://192.168.1.100:8080/control')
# Same control methods work for both communication types
bot.control_head(pan_angle=45.0)
bot.control_left_hand(gripper_angle=90.0)
bot.move_forward(speed=100)
# Close connection
bot.close()
Using Context Manager (Recommended)
from bonicbot import create_serial_controller, create_websocket_controller
# Serial connection
with create_serial_controller('/dev/ttyUSB0') as bot:
bot.control_head(pan_angle=45.0)
bot.control_left_hand(gripper_angle=90.0)
# Connection automatically closed
# WebSocket connection
with create_websocket_controller('ws://192.168.1.100:8080/control') as bot:
bot.control_head(pan_angle=45.0)
bot.move_forward(speed=100)
# Connection automatically closed
Launch GUI
Note: GUI requires tkinter (see installation instructions above)
# From command line (if tkinter available)
bonicbot-gui
# Or from Python
from bonicbot.gui import run_servo_controller
run_servo_controller()
# Check if GUI is available
from bonicbot import is_gui_available
if is_gui_available():
print("GUI available!")
else:
print("Core functionality available, GUI needs tkinter")
Core vs GUI Functionality
| Feature | Core Library | GUI Required |
|---|---|---|
| Serial robot control | ✅ Always works | N/A |
| WebSocket robot control | ✅ Always works | N/A |
| Individual servo control | ✅ Always works | N/A |
| Head/hand movements | ✅ Always works | N/A |
| Base motor control | ✅ Always works | N/A |
| Examples and scripts | ✅ Always works | N/A |
| Connection monitoring | ✅ Always works | N/A |
| Visual control interface | ❌ Needs tkinter | ✅ |
| Real-time sliders | ❌ Needs tkinter | ✅ |
| Preset position GUI | ❌ Needs tkinter | ✅ |
Communication Methods
| Method | Use Case | Pros | Cons |
|---|---|---|---|
| Serial | Direct USB connection | Low latency, reliable | Physical connection required |
| WebSocket | Network/remote control | Wireless, multiple clients | Network dependent, higher latency |
Available Servos
The library supports the following servos:
Head:
headPan: Head rotation left/right (-90° to 90°)headTilt: Head tilt up/down (-38° to 45°)
Left Arm:
leftGripper: Left gripper open/close (-90° to 90°)leftWrist: Left wrist rotation (-90° to 90°)leftElbow: Left elbow bend (-90° to 0°)leftSholderPitch: Left shoulder pitch (-45° to 180°)leftSholderYaw: Left shoulder yaw (-90° to 90°)leftSholderRoll: Left shoulder roll (-3° to 144°)
Right Arm:
rightGripper: Right gripper open/close (-90° to 90°)rightWrist: Right wrist rotation (-90° to 90°)rightElbow: Right elbow bend (-90° to 0°)rightSholderPitch: Right shoulder pitch (-45° to 180°)rightSholderYaw: Right shoulder yaw (-90° to 90°)rightSholderRoll: Right shoulder roll (-3° to 144°)
API Reference
BonicBotController Class
Constructor
BonicBotController(port: str, baudrate: int = 115200, timeout: float = 1.0)
Individual Servo Control
control_servo(servo_id: str, angle: float, speed: int = 200, acc: int = 20)
Group Controls
control_head(pan_angle: float = 0.0, tilt_angle: float = 0.0, ...)
control_left_hand(gripper_angle: float = 0.0, wrist_angle: float = 0.0, ...)
control_right_hand(gripper_angle: float = 0.0, wrist_angle: float = 0.0, ...)
control_base(left_motor_speed: int = 0, right_motor_speed: int = 0)
Movement Methods
move_forward(speed: int = 100)
move_backward(speed: int = 100)
turn_left(speed: int = 100)
turn_right(speed: int = 100)
stop()
Examples
See the examples/ directory for more comprehensive examples:
basic_control.py: Basic servo and movement controlhead_movements.py: Head tracking and scanning patternshand_gestures.py: Hand gestures and manipulation tasksbase_movement.py: Navigation and movement patterns
Hardware Requirements
- BonicBot humanoid robot
- For Serial Communication: USB to serial adapter (if not built-in)
- For WebSocket Communication: Network connection (WiFi/Ethernet)
- Python 3.7 or higher
Why isn't tkinter in requirements.txt?
tkinter is part of Python's standard library and cannot be installed via pip. It comes bundled with Python on Windows/macOS, but Linux distributions often package it separately for size optimization. This design allows:
✅ Core functionality works everywhere - Robot control without GUI dependencies
✅ Lightweight installations - Perfect for headless servers and containers
✅ Platform flexibility - Users install GUI support as needed
Bottom line: You get full robot control immediately, GUI is optional!
Supported Platforms
- Linux (Raspberry Pi recommended)
- Windows 10/11
- macOS
Contributing
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
- Fork the repository
- Create your feature branch (
git checkout -b feature/AmazingFeature) - Commit your changes (
git commit -m 'Add some AmazingFeature') - Push to the branch (
git push origin feature/AmazingFeature) - Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Support
If you encounter any issues or have questions:
- Check the documentation
- Search existing issues
- Create a new issue
Testing Your Installation
After installation, test that everything is working:
# Comprehensive installation test
from bonicbot.test_installation import test
test()
This will test:
- ✅ Core imports (BonicBotController, ServoID)
- ✅ ServoID enumeration
- ✅ GUI availability (tkinter detection)
- 📋 Platform-specific installation help if needed
Quick tests:
# Test core functionality
from bonicbot import BonicBotController, CommunicationType
print("✅ Core functionality works!")
# Test serial controller creation
from bonicbot import create_serial_controller
print("✅ Serial controller available!")
# Test WebSocket controller creation
from bonicbot import create_websocket_controller
print("✅ WebSocket controller available!")
# Test GUI availability
from bonicbot import is_gui_available
print("GUI available:", is_gui_available())
Troubleshooting
"No module named '_tkinter'" Error
This means the GUI component isn't available. The core robot control still works! To fix:
# Ubuntu/Debian
sudo apt-get install python3-tk
# Test again
from bonicbot.test_installation import test; test()
Serial Port Issues
# Permission denied
sudo usermod -a -G dialout $USER
# Then log out and back in
# Port not found - check available ports
python -c "import serial.tools.list_ports; print([p.device for p in serial.tools.list_ports.comports()])"
WebSocket Connection Issues
# Connection refused
# 1. Check robot IP address
ping 192.168.1.100
# 2. Check if WebSocket server is running
nc -zv 192.168.1.100 8080
# 3. Test WebSocket connection manually
curl -i -N -H "Connection: Upgrade" -H "Upgrade: websocket" http://192.168.1.100:8080/control
Network Discovery
# Find robots on network (if they support discovery)
import socket
def find_robots():
# This is example code - adapt to your robot's discovery method
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
sock.sendto(b"ROBOT_DISCOVERY", ("255.255.255.255", 8080))
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 bonicbot-1.2.0.tar.gz.
File metadata
- Download URL: bonicbot-1.2.0.tar.gz
- Upload date:
- Size: 37.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6322738ccf2ab9036ab1111feb3d618ccfaa747045682bb5b70da0f893ce0ae6
|
|
| MD5 |
1449a02ed56eeb6f231bb34be5ec8ca5
|
|
| BLAKE2b-256 |
7e049c547daf465ad126237fbd78e58be63063b6ae83f8660bc902fe8af647d9
|
File details
Details for the file bonicbot-1.2.0-py3-none-any.whl.
File metadata
- Download URL: bonicbot-1.2.0-py3-none-any.whl
- Upload date:
- Size: 19.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
aa4703c4d595794a7c092f546902792b803aa1a373858cf04d259e5a88c62277
|
|
| MD5 |
e199d4471165bdfd5564aa1b7eb2bab0
|
|
| BLAKE2b-256 |
b82ed0db12385f38aea77173451c1e283166741c74ed94022ed518628e81c375
|