Skip to main content

Python SDK for hiwonder TurboPi device communication

Project description

Stand With Ukraine

Fast Wonder SDK

The Fast Wonder SDK is a Python library that facilitates communication with the Hiwonder TurboPi controller. It provides easy-to-use functions for controlling various peripherals such as RGB LEDs, buzzers, infrared sensors, and more, while ensuring reliable communication with checksum validation using CRC-8.

Features

  • Control RGB LEDs: Easily control the colors of RGB LEDs using indexed tuples.
  • Control BUZZER: Simple API to control the buzzer.
  • Control Infrared Sensors: Interface with infrared sensors to detect obstacles or follow lines.
  • Control Motors:
  • Reliable Communication: Ensures data integrity with CRC-8 checksum validation for communication.
  • Configurable Serial Communication: Adjust serial communication parameters such as baud rate, timeout, etc.

Installation

To get started with Fast Wonder SDK, follow these steps:

  1. Clone the repository:
    git clone https://github.com/dmberezovskyii/fast-hiwonder.git
    

Usage

  1. Infra red sensors
    from fast_hi_wonder import InfraredSensors
    
    # Initialize the sensor with the default I2C address and bus
    sensors = InfraredSensors()
    
    # Read sensor data
    sensor_states = sensors.read_sensor_data()
    
    # Process sensor states
    for i, state in enumerate(sensor_states):
        print(f"Sensor {i+1} is {'active' if state else 'inactive'}")
    
  2. Mecanum wheels

    Polar Coordinates

In polar coordinates, we describe a point (or movement) in space using two parameters:

  • Radius (r): The distance from the origin (0,0) to the point.
  • Angle (θ): The direction of the point relative to the X-axis (horizontal axis) in degrees or radians.

In the case of your mechanism:

  • Velocity: The distance the robot moves per unit of time.
  • Direction: The angle at which the robot is moving, measured from the X-axis.

Trigonometry and Coordinate Transformation

To control the robot's movement, we break the velocity down into two components — vx and vy:

  • vx: The velocity component along the X-axis (horizontal axis).
  • vy: The velocity component along the Y-axis (vertical axis).

To calculate these components, we use trigonometric functions:

  • vx (component along the X-axis) is calculated using the cosine of the direction angle: [ vx = \text{velocity} \times \cos(\text{direction}) ]

  • vy (component along the Y-axis) is calculated using the sine of the direction angle: [ vy = \text{velocity} \times \sin(\text{direction}) ]

Example

If the robot needs to move at a speed of 100 mm/s in the direction of 30 degrees (from the X-axis):

  • ( vx = 100 \times \cos(30^\circ) )

  • ( vy = 100 \times \sin(30^\circ) )

    chassis = Motors()
    
     # Move forward at 100 mm/s in the direction of 0 degrees (forward along the X-axis)
     chassis.set_velocity(100, 0, 0)
    
     # Rotate the chassis at an angular rate of 30 degrees per second
     chassis.set_velocity(100, 0, 30)
    
     # Translate the chassis based on Cartesian coordinates (e.g., moving diagonally)
     chassis.translation(50, 50)
    
     # Stop all motors and reset movement attributes
     chassis.reset_motors()
    

External Links

You can find more information about the TurboPi robot here.

Stand With Ukraine

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

turbopi_fast_sdk-0.3.4.tar.gz (10.1 kB view details)

Uploaded Source

Built Distribution

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

turbopi_fast_sdk-0.3.4-py3-none-any.whl (12.4 kB view details)

Uploaded Python 3

File details

Details for the file turbopi_fast_sdk-0.3.4.tar.gz.

File metadata

  • Download URL: turbopi_fast_sdk-0.3.4.tar.gz
  • Upload date:
  • Size: 10.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.0.1 CPython/3.12.8

File hashes

Hashes for turbopi_fast_sdk-0.3.4.tar.gz
Algorithm Hash digest
SHA256 1cf86c44777e38cc5dddf78f3c61571698aa1fb54b1c313bd6937965d0fad7f5
MD5 2ad2e2f0c4207369e9bd4349277a64d5
BLAKE2b-256 4587f19028d2ff5c703f0d5604d840dfbf52355aee5c32dbd2509d1c6bcfe07d

See more details on using hashes here.

Provenance

The following attestation bundles were made for turbopi_fast_sdk-0.3.4.tar.gz:

Publisher: python-publish.yml on dmberezovskyii/fast-hiwonder

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file turbopi_fast_sdk-0.3.4-py3-none-any.whl.

File metadata

File hashes

Hashes for turbopi_fast_sdk-0.3.4-py3-none-any.whl
Algorithm Hash digest
SHA256 82ae6654f7a363a2a6ecb2f5d55e765fbdc4592edf122221dd66ccb1c4e97e0c
MD5 f2165e309e4d791f323fe0bc55cc6574
BLAKE2b-256 54038f997ef6027a60a0782f5bf306d821735e2addd17540401f69dfd8ab0d9a

See more details on using hashes here.

Provenance

The following attestation bundles were made for turbopi_fast_sdk-0.3.4-py3-none-any.whl:

Publisher: python-publish.yml on dmberezovskyii/fast-hiwonder

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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