Logo

dev-resources.site

for different kinds of informations.

Robot Operating System: Installation & Configuration on a Raspberry Pi with Ubuntu Server

Published at
2/21/2022
Categories
robots
raspberrypi
ubuntu
ros
Author
admantium
Categories
4 categories in total
robots
open
raspberrypi
open
ubuntu
open
ros
open
Author
9 person written this
admantium
open
Robot Operating System: Installation & Configuration on a Raspberry Pi with Ubuntu Server

There are plenty of options for developing a mobile robot. And even plentiful are the requirements that you might want to fulfill. An overall goal in all setups should be to get the most up-to-date software running, starting from the OS to the OS packages and the application libraries.

If you want to use ROS on a Raspberry Pi with the default obtain system Raspberry Pi OS, the installation is not a simple apt-get install command. The reason: there is no precompiled version for the Raspberry Pi OS. Therefore, you will need to start a lengthy process that involves manual downloading and compilation of several packages. ROS suggests using an Ubuntu OS for operating, and I can only recommend following this because you will likely find support for questions about ROS in the context of Ubuntu. Therefore, I decided to use Ubuntu Server 20.04 as the operating system for my mobile robot.

This article is a complete guide about setup, configuration and auto-starting ROS on a Raspberry Pi running Ubuntu 20.04. You will learn how to add the ROS package sources, perform the installation, configure the default user so that it has the correct permissions, and finally how to autostart the ROS code node on your Raspberry Pi at runtime.

The technical context for this article is Ubuntu Server 20.04, ROS Noetic 1.15.11, and as the hardware either a Raspberry Pi 3 or 4. All instructions should work with newer OS and library versions as well.

This article originally appeared at my blog admantium.com.

Install ROS Noetic on Ubuntu Server

By considering the steps mentioned in the official documentation, and some minor modifications, the installation boils down to this:

  1. Bring your Raspberry Pi up-to-date, including the recent kernel:
sudo apt-get update
sudu apt-get upgrade
Enter fullscreen mode Exit fullscreen mode
  1. Add the ROS package repository to your sources.list, and import the required keys.
sudo sh -c 'echo "deb http://packages.ros.org/ros/ubuntu $(lsb_release -sc) main" > /etc/apt/sources.list.d/ros-latest.list'

sudo apt-key adv --keyserver 'hkp://keyserver.ubuntu.com:80' --recv-key C1CF6E31E6BADE8868B172B4F42ED6FBAB17C654
Enter fullscreen mode Exit fullscreen mode
  1. Install the build essentials and the ROS core package
sudo apt-get update
sudo apt-get install build-essential cmake
sudo apt-get install ros-noetic-ros-base
Enter fullscreen mode Exit fullscreen mode

If all went well, let’s test the installation by running the following two commands:

source /opt/ros/noetic/setup.bash
roscore
Enter fullscreen mode Exit fullscreen mode

You should see the following output:

started roslaunch server http://omega:35395/
ros_comm version 1.15.13


SUMMARY
========

PARAMETERS
 * /rosdistro: noetic
 * /rosversion: 1.15.13
Enter fullscreen mode Exit fullscreen mode

If these steps were successful, you can continue with the next steps.

Set user Permissions

Assuming that you work with the default user pi, and that you want to work with GPIO and I2X pins of the Raspberry Pi, we need to set specific access permissions.

Execute the following commands in a terminal:

sudo groupadd -f --system gpio
sudo usermod -a -G gpio pi
sudo usermod -a -G i2c pi
Enter fullscreen mode Exit fullscreen mode

Setup a new ROS Package

To properly create ROS projects on your Raspberry Pi, follow these steps:

  1. Create a Catkin Workspace
mkdir ~/ros-noetic
cd ~/ros-noetic
Enter fullscreen mode Exit fullscreen mode
  1. Create a ROS package inside the workspace
catkin_create_pkg cmd_vel_listener std_msg rospy --rosdistro noetic

Created file cmd_vel_listener/package.xml
Created file cmd_vel_listener/CMakeLists.txt
Created folder cmd_vel_listener/src

Successfully created files in /home/pi/catkin_ws/src/cmd_vel_listener. Please adjust the values in package.xml.
Enter fullscreen mode Exit fullscreen mode
  1. Run the ROS compilation process
catkin_make
Base path: /home/pi/catkin_ws
Source space: /home/pi/catkin_ws/src
Build space: /home/pi/catkin_ws/build
Devel space: /home/pi/catkin_ws/devel
Install space: /home/pi/catkin_ws/install
####
#### Running command: "cmake /home/pi/catkin_ws/src -DCATKIN_DEVEL_PREFIX=/home/pi/catkin_ws/devel -DCMAKE_INSTALL_PREFIX=/home/pi/catkin_ws/install -G Unix Makefiles" in "/home/pi/catkin_ws/build"
####
-- Using CATKIN_DEVEL_PREFIX: /home/pi/catkin_ws/devel
-- Using CMAKE_PREFIX_PATH: /opt/ros/noetic
-- This workspace overlays: /opt/ros/noetic
-- Using PYTHON_EXECUTABLE: /usr/bin/python3
-- Using Debian Python package layout
-- Using empy: /usr/lib/python3/dist-packages/em.py
-- Using CATKIN_ENABLE_TESTING: False
-- catkin 0.8.10
-- BUILD_SHARED_LIBS is on
-- BUILD_SHARED_LIBS is on
-- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
-- ~~  traversing 4 packages in topological order:
-- ~~  - cmd_vel_listener
-- ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Enter fullscreen mode Exit fullscreen mode

After this step, you are ready to go.

Conclusion

This short article showed the essential steps to install ROS on a Raspberry Pi running Ubuntu server. By using Ubuntu, you can use available Debian packages instead of compiling everything from scratch. Installation steps include a) updates sources list, b) add the required SSH keys, c) installing the packages. Afterwards, I showed how to set correct user permissions for interacting with the GPIOs and the I2C subsystem of the Raspberry Pi. Finally, I showed how to setup a ROS workspace in which you define your projects.

ros Article's
30 articles in total
Favicon
How to Develop EtherCAT Motion Controller on ROS (2)
Favicon
How to Develop EtherCAT Motion Controller on ROS (1)
Favicon
ROS2 RViz Part-01 Tutorials: Customize RViz2 + Learn to utilize RViz visualization tools.
Favicon
ROS2 RViz Part-02 Tutorials: Learn RViz visualization tools + create Dynamic Geometric shapes.
Favicon
Learn ROS2 Fundamental concepts Explained: Nodes, Publisher, Subscriber, Messages, Topics, and More!
Favicon
Learn to create your own ROS2 Workspace, Custom Packages, Publisher and Subscriber.
Favicon
Learn ROS2 basics with a practical example i.e. using Turtlesim Simulation.
Favicon
Tutorial on ROS2 Humble installation in Ubuntu 22.04
Favicon
ROS 2 Service Tutorial: Learn to create Server-Client Communication for Robotics Integration!
Favicon
ROS2 Tutorials for beginners
Favicon
Optimal Image Storage Solutions for ROS-Based Computer Vision
Favicon
Compliant robotics & hugging people
Favicon
Looking inside ROScribe and the idea of LLM-based robotic platform
Favicon
Create Ros Library
Favicon
Learn biped robot by Zaku (ZEONIC TECHNICS)
Favicon
Seamless Robotics Integration: Setting Up micro-ROS on ESP32
Favicon
How to install ROS on Brainy Pi
Favicon
RADU: Processing & Interpreting ROS Movement Messages with Python
Favicon
RADU: Motor Controller Software for Arduino and Raspberry Pico
Favicon
RADU: Realsense D435 Installation Troubles with ROS2'
Favicon
Robotic Projects: Reasons for Switching from ROS2 to ROS1
Favicon
Augmented Reality Application for Autonomous Transport Vehicle
Favicon
ROS: Simultaneous Mapping and Localization with RTABmap
Favicon
ROS with Raspberry Pi: Investigating the Core Issue of Slow Streaming Performance
Favicon
ROS with Raspberry Pi: Improving Image Streaming Performance
Favicon
ROS with Raspberry Pi: Improving WIFI Upload Speed
Favicon
Robot Operating System: Installation & Configuration on a Raspberry Pi with Ubuntu Server
Favicon
Get Started with ROS for Embedded Robotics
Favicon
Robot Operating System: Requirements for Autonomous Navigation
Favicon
Robot Operating System: How to Model Point Cloud Data in ROS2

Featured ones: