Skip to content

zhivkopetrov/robotics_v1

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

robotics_v1

An educational C++20 Robot Operating System 2 (ROS2) Jazzy Jalisco workspace

This is the official repository for the Robotics Accelerator course, created by me and powered by Ocado Technology.

The project utilizes a personal 2D game_engine set of libraries and highly configurable thread-per-component module architecture.

The workspace contains several interesting, competitive, visual games with their respective ROS2 interfaces

  • Robo Collector - focused on learning ROS2 topics
  • Robo Miner - focused on learning ROS2 services
  • Robo Cleaner - focused on learning ROS2 actions
  • UR Dev - focused on learning UR robotic motions through URScript

You're reading the documentation for the latest version of ROS2 - Jazzy Jalisco.
An older, but still supported, version of ROS 2 - Humble Hawksbill, available under the humble branch.
An older, but End-of-Life ROS2 version - Foxy Fitzroy is still supported by this repo, available under the foxy branch.

Build Status

ROS2 Distro Jazzy Jalisco Humble Hawksbill Foxy Fitzroy
Branch
Build Status Jazzy Build Humble Build Foxy Build
OS version Ubuntu 24.04 LTS Ubuntu 22.04 LTS Ubuntu 20.04 LTS
Documentation

Previews

ur_control_gui + Rviz2 + UR ros driver 2

robo_collector_gui + robo_collector_controller

Supported Platforms & Compilers

  • Linux

    • g++ (9.3 and above)
      • Tested up to g++ 12.1
    • clang++ (10 and above)
      • Tested up to clang++ 14.0
  • Windows

    • MSVC++ (14.20 and above) Visual Studio 2019
      • Tested up to 17.30 Visual Studio 2022
      • Note: enable Linux Bash Shell support under Windows to utilise the preset build scripts
      • Note2: although the game-engine is fully MSVC++ compatible, I haven't tested actual ROS2 functionalities on Windows

Project automated installation

All dependencies in the project could be conveniently installed via preset install scripts. For manual installation refer to 'Dependencies' and 'Third party libs' sections below.

Please note that ROS2 installation could be quite bulky. For reference, a fresh Ubuntu 22.04 docker image with all compilers, tools, libs and ROS2 installed is close to 7GB. That number could be reduced, but it's not a focus for this repository.

Host usage

# Warning, the script will install dependencies directly on your host
sudo ./scripts/assisted_install/full_install_on_host.sh

Once the installation phase finishes, for convinience, you can add manual steps to your bashrc. This way each time you open a NEW terminal session, they will be populated for you.

echo "export LANG=en_US.UTF-8" >> ~/.bashrc
echo "source /opt/ros/jazzy/setup.bash" >> ~/.bashrc
echo "source source /usr/share/colcon_cd/function/colcon_cd-argcomplete.bash" >> ~/.bashrc

Docker support

  • Requires Docker Engine (18.09.1 and above)
    • Tested up to Docker Engine 20.10.23
# All parameters are optional

# Clone dependencies on fresh Ubuntu 24.04 image, build and install artifacts
./scripts/assisted_install/full_install_in_docker.sh <os_version> <ros2_distro> <enable_vnc_server> <enable_docker_in_docker>

# By default os_version=ubuntu:24.04 ros2_distro=jazzy, enable_vnc_server=False, enable_docker_in_docker=False

# Start the image
./scripts/run/run_docker_file.sh <ros2_distro> <enable_privileged_mode>

# By default ros2_distro=jazzy, enable_privileged_mode=False
# Privileged mode is required if you want to enable docker in docker support.
# For example starting the Universal Robots Simulator docker image inside robotics_v1 docker image (Docker in Docker)

# To access the VNC Server use a VNC Client of your choice
# For example VNC Viewer - https://www.realvnc.com/en/connect/download/viewer/

Access the VNC Server using local host and port 5920
Address: 127.0.0.1:5920
Password: robotics_v1

Doing so will lead you to Fluxbox.
Fluxbox is an extemely basic and lightweight stacking window manager for the X Window System.
All you need is probably a terminal session.
Right click -> Applications -> Shells -> Bash

Colcon configuration. Building the project

Use plain Colcon commands to configure and build the project or use some of the existing preset build scripts.

Basic usage

Automatic asset generation + build + install steps

./scripts/assisted_build/full_build.sh

Build + install steps

./scripts/assisted_build/partial_build.sh

Advanced usage

# all parameters listed in the scripts are optional

# A full build is required only once in the beginning.
# For more information refer to the 'Automatic asset information generation' section
./scripts/assisted_build/full_build.sh <build_type> <verbose_build> <additional_colcon_options>

# A partial build is the prefered, fast, with minimal compilation (build + install) procedure
./scripts/assisted_build/partial_build.sh <build_type> <verbose_build> <additional_colcon_options>

# <build_type> - Debug / Release / RelWithDebInfo / MinSizeRel
# Defaults to Debug
# This param is passed to CMAKE_BUILD_TYPE
# https://cmake.org/cmake/help/latest/variable/CMAKE_BUILD_TYPE.html

# <verbose_build> - True / False
# Defaults to False
# Verbose output for build and install steps

# <additional_colcon_options> - colcon specific parameters
# Defaults to none

# For plain colcon commands run 'colcon build --help'
# Or refer to the official colcon documentation:
# https://docs.ros.org/en/jazzy/Tutorials/Beginner-Client-Libraries/Colcon-Tutorial.html

Automatic asset information generation

The first time the project is manually build it will fail compilation. The reason is because of missing auto-generated headers. Those headers contain asset information such as image/sprite/text/sound texture data, asset locations, load policies, etc... To auto-generate them use the following instructions:

# all parameters listed in the scripts are optional

./scripts/assisted_build/generate_asset_info.sh <build_type> <verbose_build> <additional_colcon_options>

# Note: the build preset script 'full_build.sh' already invoke 'generate_asset_info.sh' for you

Asset information generation should be executed only once in the beginning. Or everytime you modify some of the assets or resource files (asset information descriptions)

Running the project

The project is composed of multiple ros2 packages, most of which contain a GUI.
Important: as per colcon documentation - don't run ROS2 packages from the same terminal session used for building.
Instead run them from a separate terminal session.

General guidance

Once the project is build - source its installed artifacts.
This should be done for each NEW terminal session

source install/setup.bash

Run nodes via normal colcon commands (ros2 run/launch).

Robo games

ros2 launch robo_collector_gui launch.py
ros2 launch robo_collector_controller launch.py
ros2 launch robo_miner_gui launch.py
ros2 launch robo_cleaner_gui launch.py
# Note that 'ros2 launch' will load config files, while 'ros2 run' will use the default ones

Universal Robots Application suite setup

If real hardware robot is used, the application suite will pick it up automatically.
If instead a Universal Robots Simulator (URSim) is used, start it with:

./scripts/run/run_ursim.sh <ur_type>

Supported ur_types: ur3/ur3e/ur5/ur5e/ur10/ur10e.
ur16/ur16e are supported as parameters, but their URDFs are not present.
Note that URSim does not support ARM based CPUs.

Starting the Universal Robots ROS2 driver:

./scripts/run/run_ur_driver.sh <ur_type> <robot_ip> <launch_rviz>

Example usage with ur10e robot configured to connect with URSim

./scripts/run/run_ur_driver.sh ur10e 192.168.56.101 true

Helper utility node, exposing beginner-friendly API from the robot.

ros2 launch urscript_bridge launch.py

Helper GUI nodes, which can control real hardware or a simulated robot.
The nodes are utilising the robot API exposed from the 'urscript_bridge' node.

ros2 launch ur_control_gui launch.py
ros2 launch ur_control_bloom launch.py

ur_control_gui is a high-level control application suited for executing raw URScripts.
ur_control_bloom provides more sophisticated control concepts such as:

  • Execution of blocking or async motion commands
  • Graceful/immediate abort of motion trajectories
  • Constructing gripper/motion/robot URScripts with source code primitives
  • Configurable high-level state machine and low-level motion sequences
  • Configurable motion strategies (behavior) based on config
  • Gripper full hardware support and basic simulation support

Hardware requirements

This project utilizes hardware-accelerated graphics. Any low-end GPU (integrated or dedicated) will be sufficient. CPU usage is neglectable for the majority of projects and low-demanding for the Universal Robots Driver.

If however hardware-accelerated graphics could not be used - the GUI fallbacks to software rendering. This could be the case if the project is ran inside a Virtual Machine with no hardware-acceleration. Or if a cloud-hosted Virtual Machine is used. The majority of those lack hardware-acceleration support. If Software rendering is used - the CPU usage will skyrocket. By default the GUI is confgured to run at 60 FPS, which when using software rendering may hit the 100% CPU mark.

Support for hardware-restrained (CPU cores and/or RAM) - a.k.a. toaster build

By default the colcon build system utilizes a parallel executor (simultaneous package build/install instructions). If your package dependency graph allows it up-to <hardware_concurrency> CPU cores could be utilised.

# The simultaneous processed packages could be controlled with <additional_colcon_options>
--parallel-workers NUMBER (defaults to <hardware_concurrency>)

Additionally, the generation of ROS2 interfaces is an especially RAM intensive operation.

  • Reference stats for a clean project build on 8 parallel CPU cores:
    • Using clang++ yields a peak of 800% CPU usage and 5 GB of RAM usage
    • Using g++ yields a peak of 800% CPU usage and 9 GB of RAM usage
      • Any subsequent builds then utilize only a small portion of the hardware resources

To relief the hardware usage spike for initial builds:

# Pass a ' --parallel-workers 1' as <additional_colcon_options>

# Or completely change the executor type to 'sequential'
# Pass a ' --executor sequential' as <additional_colcon_options>
# You can achieve this step conveniently by invoking the following preset build script:
./scripts/assisted_build/toaster_build.sh <build_type> <verbose_build> <additional_colcon_options>

# any parameters passed to <additional_colcon_options> will be appended to the ' --executor sequential' option

Dependencies (personal open-source libraries and tools)

This step decribes the manual installation of dependencies. For automated/assisted install refer to the 'Project automated installation' section. Dependencies are integrated as git submodules.

  • To clone them, step inside the repository and run the following instructions
git submodule init
git submodule update

Those commands will clone the following repositories:

Third party libs, which are not shipped with this repository

This step decribes the manual installation of third party libs. For automated/assisted install refer to the 'Project automated installation' section.

  • ROS2 Jazzy Jalisco

  • Boost

  • SDL2 family libraries - SDL2, SDL2-image, SDL2-ttf, SDL2-mixer

    • Linux
      • Install through apt is sufficient
        sudo apt install libsdl2-dev libsdl2-ttf-dev libsdl2-image-dev libsdl2-mixer-dev
        
    • Windows
      • Download SDL2 packages from the official SDL2 repository
      • Extract under "C:/SDL2" or alongside the project binary

Dependency hierarchy diagrams

Robo Games

UR Dev

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published