Skip to main content

Modular Robot System With Elegant Automation Capabilities

Project description

RoSys - The Robot System

RoSys provides an easy-to-use robot system. Its purpose is similar to ROS. But RoSys is fully based on modern web technologies and focusses on mobile robotics.

The full documentation is available at rosys.io.

Principles

All Python

Python is great to write business logic. Computation-heavy tasks are wrapped in processes, accessed through WebSockets or called via C++ bindings. Like you would do in any other Python program.

Modularity

You can structure your code as you please. RoSys provides its magic without assuming a specific file structure, configuration files or enforced naming.

Event Loop

Thanks to asyncio you can write your business logic without locks and mutexes. The execution is parallel but not concurrent which makes it easier to read, write and debug. In real-case scenarios this is also much faster than ROS. Its multiprocessing architecture requires too much inter-process communication.

Web UI

Most machines need some kind of human interaction. RoSys is built from the ground up to make sure your robot can be operated fully off the grid with any web browser. This is done by incorporating NiceGUI, a wonderful all-Python UI web framework. It is also possible to proxy the user interface through a gateway for remote operation.

Simulation

Robot hardware is often slower than your own computer. To rapidly test out new behavior and algorithms, RoSys provides a simulation mode. Here, all hardware is mocked and can even be manipulated to test wheel blockages and similar.

Testing

You can use pytest to write high-level integration tests. It is based on the above-described simulation mode and accelerates the robot's time for super fast execution.

Architecture and Features

Modules

RoSys modules are just Python modules which encapsulate certain functionality. They can hold their own state, register lifecycle hooks, run methods repeatedly and subscribe to or raise events. Modules can depend on other modules which is mostly implemented by passing them into the constructor.

Lifecycle Hooks and Loops

Modules can register functions via rosys.on_startup or rosys.on_shutdown as well as repeatedly with a given interval with rosys.on_repeat.

!!! note Note that NiceGUI's app object also provides methods app.on_startup and app.on_shutdown, but it is recommended to use RoSys' counterparts: rosys.on_startup ensures the callback is executed after persistent modules have been loaded from storage. If you, e.g., set the rosys.config.simulation_speed programmatically via app.on_startup() instead of rosys.on_startup, the change is overwritten by RoSys' persistence.restore().

Events

Modules can provide events to allow connecting otherwise separated modules of the system. For example, one module might read sensor data and raise an event NEW_SENSOR_DATA, without knowing of any consumers. Another module can register on NEW_SENSOR_DATA and act accordingly when being called.

Automations

RoSys provides an Automator module for running "automations". Automations are coroutines that can not only be started and stopped, but also paused and resumed, e.g. using AutomationControls. Have a look at our Click-and-drive example.

Persistence

Modules can register backup and restore methods to read and write their state to disk.

Time

RoSys uses its own time which is accessible through rosys.time. This way the time can advance much faster in simulation and tests if no CPU-intensive operation is performed. To delay the execution of a coroutine, you should invoke await rosys.sleep(seconds: float). This creates a delay until the provided amount of RoSys time has elapsed.

Threading and Multiprocessing

RoSys makes extensive use of async/await to achieve parallelism without threading or multiprocessing. But not every piece of code you want to integrate is offering an asyncio interface. Therefore RoSys provides two handy wrappers:

IO-bound: If you need to read from an external device or use a non-async HTTP library like requests, you should wrap the code in a function and await it with await rosys.run.io_bound(...).

CPU-bound: If you need to do some heavy computation and want to spawn another process, you should wrap the code in a function and await it with await rosys.run.cpu_bound(...).

Safety

Python (and Linux) is fast enough for most high-level logic, but has no realtime guarantees. Safety-relevant behavior should therefore be put on a suitable microcontroller. It governs the hardware of the robot and must be able to perform safety actions like triggering emergency hold etc.

We suggest to use an industrial PC with an integrated controller like the Zauberzeug Robot Brain. It provides a Linux system to run RoSys, offers AI acceleration via NVidia Jetson, two integrated ESP32 microcontrollers and six I/O sockets with up to 24 GPIOs for digital I/Os, CAN, RS485, SPI, I2C, etc. It also has two hardware ENABLE switches and one which is controllable via software.

To have flexible configuration for the microcontroller we created another open source project called Lizard. It is a domain-specific language interpreted by the microcontroller which enables you to write reactive hardware behavior without recompiling and flashing.

User Interface

RoSys builds upon the open source project NiceGUI and offers many robot-related UI elements. NiceGUI is a high-level UI framework for the web. This means you can write all UI code in Python and the state is automatically reflected in the browser through WebSockets. See any of our examples.

RoSys can also be used with other user interfaces or interaction models if required, for example a completely app-based control through Bluetooth Low Energy with Flutter.

Notifications

Modules can notify the user through rosys.notify('message to the user'). When using NiceGUI, the notifications will show as snackbar messages. The history of notifications is stored in the list rosys.notifications.

Contributing

Thank you for your interest in contributing to RoSys! We are thrilled to have you on board and appreciate your efforts to make this project even better.

As a growing open-source project, we understand that it takes a community effort to achieve our goals. That's why we welcome all kinds of contributions, no matter how small or big they are. Whether it's adding new features, fixing bugs, improving documentation, or suggesting new ideas, we believe that every contribution counts and adds value to our project.

We have provided a detailed guide on how to contribute to RoSys in our CONTRIBUTING.md file. We encourage you to read it carefully before making any contributions to ensure that your work aligns with the project's goals and standards.

If you have any questions or need help with anything, please don't hesitate to reach out to us. We are always here to support and guide you through the contribution process.

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

rosys-0.18.4.tar.gz (231.5 kB view details)

Uploaded Source

Built Distribution

rosys-0.18.4-py3-none-any.whl (294.8 kB view details)

Uploaded Python 3

File details

Details for the file rosys-0.18.4.tar.gz.

File metadata

  • Download URL: rosys-0.18.4.tar.gz
  • Upload date:
  • Size: 231.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.10.12 Linux/6.5.0-1025-azure

File hashes

Hashes for rosys-0.18.4.tar.gz
Algorithm Hash digest
SHA256 ecda74ba27bc83c2700cc4100653203a86102559b6c254d45b6eeff50a857d0a
MD5 78938e5a13481a1ec1ef9bd0127cf360
BLAKE2b-256 3b799d1ccc8f40d1c361a91a8cea460b050b1343b7e773e5e1fb767b440afd89

See more details on using hashes here.

File details

Details for the file rosys-0.18.4-py3-none-any.whl.

File metadata

  • Download URL: rosys-0.18.4-py3-none-any.whl
  • Upload date:
  • Size: 294.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.4 CPython/3.10.12 Linux/6.5.0-1025-azure

File hashes

Hashes for rosys-0.18.4-py3-none-any.whl
Algorithm Hash digest
SHA256 318aa51fae11ad6c1a20e801e510271e771f579bd4c69e5981d2f28435ccc5d8
MD5 fea3214c0bbce91dabe6858a2aa4c40d
BLAKE2b-256 0b9d53b4cb459454e0fce5fa704f507b286ea22bbef462046e03e097c8a79592

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page