Skip to main content

Python library for controlling BonicBot humanoid robot via serial communication and WebSocket

Project description

BonicBot Python Library

PyPI version Python versions License: MIT

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 control
  • head_movements.py: Head tracking and scanning patterns
  • hand_gestures.py: Hand gestures and manipulation tasks
  • base_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.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. 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:

  1. Check the documentation
  2. Search existing issues
  3. 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bonicbot-1.2.0.tar.gz (37.8 kB view details)

Uploaded Source

Built Distribution

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

bonicbot-1.2.0-py3-none-any.whl (19.3 kB view details)

Uploaded Python 3

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

Hashes for bonicbot-1.2.0.tar.gz
Algorithm Hash digest
SHA256 6322738ccf2ab9036ab1111feb3d618ccfaa747045682bb5b70da0f893ce0ae6
MD5 1449a02ed56eeb6f231bb34be5ec8ca5
BLAKE2b-256 7e049c547daf465ad126237fbd78e58be63063b6ae83f8660bc902fe8af647d9

See more details on using hashes here.

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

Hashes for bonicbot-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 aa4703c4d595794a7c092f546902792b803aa1a373858cf04d259e5a88c62277
MD5 e199d4471165bdfd5564aa1b7eb2bab0
BLAKE2b-256 b82ed0db12385f38aea77173451c1e283166741c74ed94022ed518628e81c375

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