Skip to main content

Scheduler for automation tasks that involve multiple stations/workers.

Project description

Binder PyPI version codecov

roboflo

pip install roboflo

Task scheduler for any system with coordinated workers. The original use case is for the Perovskite Automated Spin-Coating Assembly Line (PASCAL) in the Fenning Lab at UC San Diego, where a robotic arm moves small glass slides between stations to perform experiments.

roboflo assumes that you have a set of Worker's that act (independently or in unison) to perform Task's of set duration. Furthermore, one or more Worker's can function to transition between Task's (eg my robot moves a sample from the hotplate to a camera, or my mom moves me from school to soccer practice). These transition moves constitute a special case of Task's , called Transition's. The total set of Worker's and Transition's define your System. Sets of Task's are consolidated into Protocol's (eg the same process for five samples or five kids), which are then scheduled (using the Scheduler on your System) to minimize the total working time. An example schedule is shown below.

Happy robot-ing!

Example Schedule

PS - shoutout to Taskpacker, from which I drew heavy inspiration. roboflo carries much of the design philosophy from Taskpacker, but uses only Python packages (the backend is Google ORTools as opposed to Numberjack, which can be difficult to install especially on Windows). roboflo also introduces Transitions, which define a finite state machine, as a critical component in the workflow under the assumption that many robotic platforms involve workers whose specific jobs are to move things between other workers.

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

roboflo-0.2.1.tar.gz (27.1 kB view details)

Uploaded Source

Built Distribution

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

roboflo-0.2.1-py3-none-any.whl (28.7 kB view details)

Uploaded Python 3

File details

Details for the file roboflo-0.2.1.tar.gz.

File metadata

  • Download URL: roboflo-0.2.1.tar.gz
  • Upload date:
  • Size: 27.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for roboflo-0.2.1.tar.gz
Algorithm Hash digest
SHA256 325ae66f3b0315c2fb727bf1637bcc1b4e4b4b7ca191c58cc322aa59bbc141d3
MD5 4c26dcebcf9ebfcb63628f451feb2daf
BLAKE2b-256 9993a50b2774b1432a7ff417f4ee6272cdcc9e19b03cd936ea2c721d62fcf723

See more details on using hashes here.

File details

Details for the file roboflo-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: roboflo-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 28.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for roboflo-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 4688216d1e6ad212ea9624ecda406539c50ae09e49756e30ae65e8e7d2055f16
MD5 59a0d4bdcbf8db00ba5b72730152131f
BLAKE2b-256 4d1f50d63c7bfa7aed4ebf9173be606048168cd1543cad1432b551a7a18cd98d

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