Skip to main content

A robot API for the educational robotics course

Project description

sourcebots

Lint & build PyPI version MIT license Bees

sourcebots - SourceBots Robot API

This is the API for Southampton Robotics Outreach robotics competitions.

Installation

If you wish to install openCV from your package manager, you can install the base package with:

pip install sourcebots

To install the full package, including openCV, you can install with:

pip install sourcebots[vision]

Usage

Importing the module will, by default, trigger board discovery and wait for the start button to be pressed.

import sbot

Unlike previous versions, robot functionality is accessed directly from the sbot library instead of instantiating a class.

from sbot import *

motors.set_power(0, 0.3)
motors.set_power(1, 0.3)

power.get_output_current(PowerOutputPosition.H0)
utils.sound_buzzer(880, 0.5)

servos.set_position(0, 45/90)

print(arduino.measure_ultrasound_distance(8, 9))

if comp.is_competition:
    markers = vision.detect_markers()
    leds.set_colour(0, Colour.MAGENTA)

Startup behaviour

You can configure the startup behaviour of sbot with an override.env file in the same directory as your project.

Example override.env file:

ENABLE_DEBUG_LOGGING=1
SKIP_WAIT_START=1
NO_POWERBOARD=1

If SKIP_WAIT_START is set, you will have to manually trigger board discovery and wait for the start button:

from sbot import utils

utils.load_boards()
utils.wait_start()

The currently supported override keys are:

Override Description
ENABLE_DEBUG_LOGGING Enable debug logging
ENABLE_TRACE_LOGGING Enable trace level logging
SKIP_WAIT_START Don't block for the start signal automatically
NO_POWERBOARD Allow running without a power board
MANUAL_POWER_PORTS Specify additional serial ports for power boards
MANUAL_MOTOR_PORTS Specify additional serial ports for motor boards
MANUAL_SERVO_PORTS Specify additional serial ports for servo boards
MANUAL_ARDUINO_PORTS Specify additional serial ports for arduino boards
MANUAL_LED_PORTS Specify additional serial ports for led boards, only used in the simulator
MANUAL_TIME_PORTS Specify additional serial ports for the time interface, only used in the simulator
SORT_POWER_ORDER Override the sort order of the power boards, unused
SORT_MOTOR_ORDER Override the sort order of the motor boards
SORT_SERVO_ORDER Override the sort order of the servo boards
SORT_ARDUINO_ORDER Override the sort order of the arduino boards, unused
SORT_LED_ORDER Override the sort order of the led boards, unused
SORT_TIME_ORDER Override the sort order of the time interface, unused

You can also configure these settings as environment variables, by prepending the prefix SBOT_. For example, ENABLE_DEBUG_LOGGING can be set as SBOT_ENABLE_DEBUG_LOGGING. Some settings can only be configured as environment variables. These are:

Environment Variable Description
OPENCV_CALIBRATIONS Override the location to look for additional camera calibrations, defaults to the working directory
SBOT_METADATA_PATH Override the location to look for metadata files, normally configured by the runner
SBOT_PYTEST Set to 1 when running unit tests, to disable automatic discovery on import
SBOT_MQTT_URL The URI to use for the MQTT broker, normally configured by the runner
run_uuid The UUID to include in all MQTT messages, normally configured by the runner
WEBOTS_SIMULATOR Set to 1 when running in the Webots simulator, used to detect the simulator environment
WEBOTS_ROBOT List of socket URIs to connect to for the simulated boards, configured by the runner
WEBOTS_DEVICE_LOGGING Set to the log level name to use for logging of the simulated boards, defaults to WARNING

Developer Notes

There are a number of considerations that have been made in the design of this API. Some of these may not be immediately obvious, so they are documented below.

  • tuple is used to prevent the user from adding, removing or overwriting items in any parts of the API that would return a list.
  • __slots__ is used to prevent the user from adding, removing or overwriting attributes in any parts of the API.
  • sbot.serial_wrapper.SerialWrapper handles automatic reconnection to the serial port if the connection is lost and impleents 3 retries on any serial operation before raising a BoardDisconnectionError.
  • The old API is still available under sbot.historic, though this might change.

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

sourcebots-0.0.1.tar.gz (69.0 kB view details)

Uploaded Source

Built Distribution

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

sourcebots-0.0.1-py3-none-any.whl (72.4 kB view details)

Uploaded Python 3

File details

Details for the file sourcebots-0.0.1.tar.gz.

File metadata

  • Download URL: sourcebots-0.0.1.tar.gz
  • Upload date:
  • Size: 69.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sourcebots-0.0.1.tar.gz
Algorithm Hash digest
SHA256 10cd2a208d2426c550d54a2cb07cc0e1e0275f666d7a571f133de30c39471d1d
MD5 6f79f09a402698208a3d374760530119
BLAKE2b-256 9f5f2ee4aad64322e04f284666a3578c5fa0198e59e90e8a5b6747383beb351d

See more details on using hashes here.

Provenance

The following attestation bundles were made for sourcebots-0.0.1.tar.gz:

Publisher: test_build.yml on sourcebots/sourcebots

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

File details

Details for the file sourcebots-0.0.1-py3-none-any.whl.

File metadata

  • Download URL: sourcebots-0.0.1-py3-none-any.whl
  • Upload date:
  • Size: 72.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sourcebots-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 38c74c29e1a40116fbf9de189fc16c0baadc37d2d8b56a962685a9284ca0585c
MD5 18e6970f5b0b378dac53713faa4efb47
BLAKE2b-256 40b909f797305d5ffceae3bea4a0d1fb308e8c7daef911ef1bbe797015f1eefd

See more details on using hashes here.

Provenance

The following attestation bundles were made for sourcebots-0.0.1-py3-none-any.whl:

Publisher: test_build.yml on sourcebots/sourcebots

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