Skip to main content

A tool to generate Dockerfiles for use in robotics, as well as a script to build and enter these containers, with support for graphical applications, GPU passthrough, realtime scheduling, host networking and full device access.

Project description

Robot Containers

This repository contains Dockerfiles for building containers for various robots. It also includes a python script run.py that wraps the docker command to enable:

  • building, starting and entering the container in one step
  • graphical applications
  • nvidia GPU passthrough
  • realtime scheduling
  • host networking
  • full external device access (USB, cameras, etc.)

Finally, it includes roboco, a script for generating a new project from the included Dockerfiles.

CI - Test CI - Docker Images linting - Ruff code style - Black types - Mypy License - MIT image image

Table of Contents

Requirements

Docker

nvidia-docker2 (for GPU support, optional)

VSCode - Dev Containers Extension (Optional)

Installation

Using pip

pip install roboco

Using git

git clone https://github.com/monashrobotics/robot_containers.git
cd robot_containers
pip install .

Usage

Adding a container to your project

roboco init

Follow the prompts to select the robot type and additional features.

Once completed, there will be two new files in your current directory: Dockerfile and run.py.

Running the container

Build the image and run the container using:

./run.py

Customising the container

The Dockerfile can be edited to add additional dependencies or change the base image.

When you make changes to the Dockerfile, you will need to rebuild the image using:

./run.py build

Then remove the old container and start a new one:

./run.py rm
./run.py

Available Dockerfile Templates

Dockerfile templates are available for the following robot / ROS / Ubuntu combinations.

Robot / ROS Distro (Ubuntu OS) ROS 1 Noetic (20.04) ROS 2 Foxy (20.04) ROS 2 Humble (22.04)
ABB YuMi WIP
Baxter WIP
Fetch WIP
Jackal WIP WIP WIP
Panda WIP
Ridgeback WIP
UR5 WIP

Generic ROS 1 and ROS 2 Dockerfile templates for the following distributions are also available:

  • ROS 1 Kinetic (16.04)

  • ROS 1 Melodic (18.04)

  • ROS 1 Noetic (20.04)

  • ROS 2 Foxy (20.04)

  • ROS 2 Galactic (20.04)

  • ROS 2 Humble (22.04)

Hardware Drivers

Snippets are available for these hardware drivers and ROS distro combinations:

Driver / ROS Distro (Ubuntu OS) ROS 1 Noetic (20.04) ROS 2 Foxy (20.04) ROS 2 Humble (22.04)
RealSense Camera WIP WIP WIP
Velodyne LiDAR WIP WIP WIP
Robotiq 2F-85 Gripper WIP
Robotiq FT-300 Force-Torque Sensor WIP

Software Snippets

Snippets are available for the following software packages:

Software ROS 1 Noetic (20.04) ROS 2 Foxy (20.04) ROS 2 Humble (22.04)
pytorch WIP WIP WIP

Contributing

If there's a robot, or hardware driver that you'd like to see supported, please open an issue or pull request. See CONTRIBUTING.md

Troubleshooting

See docs/troubleshooting.md

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

roboco-0.0.4.tar.gz (46.1 kB view details)

Uploaded Source

Built Distribution

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

roboco-0.0.4-py3-none-any.whl (23.2 kB view details)

Uploaded Python 3

File details

Details for the file roboco-0.0.4.tar.gz.

File metadata

  • Download URL: roboco-0.0.4.tar.gz
  • Upload date:
  • Size: 46.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.24.1

File hashes

Hashes for roboco-0.0.4.tar.gz
Algorithm Hash digest
SHA256 c33fc958f7b04908b73417ab4eb68aa0718a7f5360cb141ff7c41d8c91f18d65
MD5 9173df6a1dd3b62a0ec0a68e45fbb649
BLAKE2b-256 9ea8bca4c0cf78fc5404ce3bda658a9dd3200dde6097e6835f327cf9ee955e2c

See more details on using hashes here.

File details

Details for the file roboco-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: roboco-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 23.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-httpx/0.24.1

File hashes

Hashes for roboco-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 e7fca253a3f9d81a9f282650dc123100a7e0c450541250b95562794f0b3fcda4
MD5 312d6e2fe6255b8a8ee9ac926f00faeb
BLAKE2b-256 8390704a75e1379a68bf33042c5118bbc6e748dab696258365214f0f10fe633e

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