Complete all of the following steps to setup your Intro Robotics programming environment:
For this course, the most ideal programming environment is the Ubuntu 20.04 Operating System. There are many ways to configure an Ubuntu 20.04 programming environment (virtual machines, an Ubuntu 20.04 partition on your laptop). Additionally, you can use ROS outside Ubuntu (ROS for Windows, ROS2, ROS through Windows Subsystem for Linux). Here are our recommendations for configuring your programming environment based on the native operating system of your computer:
Follow these instructions to install ROS Noetic, installing
ros-noetic-desktop-full
.
These instructions are based on those found on the ROBOTIS website. Install these necessary ROS dependencies:
$ sudo apt-get install ros-noetic-joy ros-noetic-teleop-twist-joy ros-noetic-teleop-twist-keyboard ros-noetic-laser-proc ros-noetic-rgbd-launch ros-noetic-rosserial-arduino ros-noetic-rosserial-python ros-noetic-rosserial-client ros-noetic-rosserial-msgs ros-noetic-amcl ros-noetic-map-server ros-noetic-move-base ros-noetic-urdf ros-noetic-xacro ros-noetic-compressed-image-transport ros-noetic-rqt-image-view ros-noetic-gmapping ros-noetic-navigation ros-noetic-interactive-markers
$ sudo apt-get install ros-noetic-ros-control*
$ sudo apt-get install ros-noetic-control* -o Dpkg::Options::="--force-overwrite"
$ sudo apt-get install ros-noetic-moveit*
catkin_ws
These instructions are based on this ROS tutorial page. Carry out the following commands:
$ source /opt/ros/noetic/setup.bash
$ mkdir -p ~/catkin_ws/src
$ cd ~/catkin_ws/
$ catkin_make
Then, add the source catkin_ws/devel/setup.bash
command to your ~/.bashrc
file.
$ echo "source ~/catkin_ws/devel/setup.bash" >> ~/.bashrc
catkin_make
command or open a new terminal, you'll need to source the
catkin_ws/devel/setup.bash
file, which is why we're adding it to the ~/.bashrc
file.
To ensure that you've set up your catkin workspace properly: 1) close your current terminal window, 2) open a new
terminal window, and 3) enter the command roscd. If you've set up your catkin workspace correctly, you
should now be in the directory ~/catkin_ws/devel
.
Next, navigate to your catkin workspace's src
folder and clone the necessary git repositories used
for the Turtlebot3:
$ cd ~/catkin_ws/src
$ git clone https://github.com/ROBOTIS-GIT/turtlebot3_msgs.git
$ git clone -b noetic-devel https://github.com/ROBOTIS-GIT/turtlebot3.git
$ git clone https://github.com/ROBOTIS-GIT/turtlebot3_simulations.git
$ git clone -b develop https://github.com/ROBOTIS-GIT/turtlebot3_manipulation.git
$ git clone https://github.com/ROBOTIS-GIT/turtlebot3_manipulation_simulations.git
$ git clone https://github.com/ROBOTIS-GIT/open_manipulator_dependencies.git
Finally, run the catkin_make
command within your catkin workspace, source the
devel/setup.bash
file, and set your default turtlebot3 model to the waffle pi.
$ cd ~/catkin_ws && catkin_make
$ source devel/setup.bash
$ echo "export TURTLEBOT3_MODEL=waffle_pi" >> ~/.bashrc
You can test to ensure that you've installed all of the Turtlebot3 packages and dependencies by trying out a built-in teleoperation demo of the Turtlebot3 in a simulated house environment. You'll need to run the following commands in 3 separate terminal windows (or terminal tabs).
Terminal 1:
$ roscore
Terminal 2:
$ roslaunch turtlebot3_gazebo turtlebot3_house.launch
You should now see a Turtlebot3 waffle (without the arm) within a simulated house environment:
Terminal 3:
$ roslaunch turtlebot3_teleop turtlebot3_teleop_key.launch
Follow the directions in the terminal to teleoperate your simulated turtlebot3!
In the last step, we setup the the class repository. The class package is where you will place your scripts and
use common course utilities. Navigate to your catkin workspace's src
folder, clone the class
repository and pull all of its submodules:
$ cd ~/catkin_ws/src
$ git clone https://github.com/Intro-Robotics-UChicago-Spring-2022/intro_robo.git
$ cd intro_robo
$ git submodule update --init --recursive
Then, similar to before, run the catkin_make
command within your catkin workspace and source the
devel/setup.bash
file.
$ cd ~/catkin_ws && catkin_make
$ source devel/setup.bash
The class repository contains several important catkin packages:
lab_letter_exercise
: These packages contain the necessary files for
conducting the lab exercises. The letter specifies the lab and the exercise specifies the specific
exercise the package is addressing. For instance the lab_a_stop_at_wall
is for the stop at wall
exercise in lab A.We will update the class package throughout the course to add new class meeting packages. Hence, you should update this package and build it prior to each class meeting. You can do so via the following commands:
$ cd ~/catkin_ws/src/intro_robo
$ git submodule update --init --recursive
$ cd ~/catkin_ws && catkin_make
$ source devel/setup.bash
We recommend using VSCode to develop ROS
applications. The autocomplete features from VSC extensions are very helpful when first learning rospy
.
These are the extensions that we found helpful:
Here's also a guide to managing extensions in VSCode.
If you are unfamiliar with Ubuntu or Gnome, we recommend that you take some time to familiarize with the user interface and the functionalities. Here is a short intro the gnome desktop. Additionally, students in the past have found the following tidbits helpful,
To get started with an Ubuntu VM, you'll first need to download VirtualBox, an open-source virtualization program available on most major operating systems. You can download the appropriate version for your machine here, under "VirtualBox platform packages". Once downloaded, follow the installation wizard provided by VirtualBox.
Once VirtualBox is installed, you can now load in the Ubuntu VM we've created for this class. Follow these steps:
.vmdk
and .ovf
file from this link. Make sure both files are downloaded to
the same directory.File > Import Appliance
..ovf
file is saved and import it into the
blank "File:" field. Press "Continue".Settings > System
and increase "Base Memory" to 2048MB.Settings > Display
and increase "Video Memory" to 40MB.Your VM should now be ready to boot!
The default password for the VM is: ubuntu
.
When you want to power off the VM, simply close the window running the VM. You will be presented with three options:
Do NOT select "Power off the machine"! This option has been known to cause many issues. Instead, select either "Save the machine state" (recommended option, as it saves the VM the way you leave it) or "Send the shutdown signal" (shuts down the VM).
In order to teleoperate the Turtlebot3, your machine and your Ubuntu VM will need to be connected to it via the
same Wi-Fi network.
This network will most likely be the router that is being used for the class (intro-robo
). Follow the
steps below:
Settings > Network
in the GUI.Adapter 1
tab, which should be the default. In the Attached to:
field,
set the option to Bridged Adapter
, if it isn't already.Adapter 1
, set the Name:
field to your wireless
adapter. On a Mac, this will likely be en0: Wi-Fi (Wireless)
.
Adapter 1
, click the refresh button to the right of the
MAC Address
field to ensure that your virtual machine has a unique address.
Adapter 2
tab. Set Attached to:
to Internal Network
. The
Name:
field should already be set to intnet
-- go ahead and change it if it's not.
ROS should already be installed on your VM, but you will not be able to use ROS commands from the terminal without running a setup script. If this is your first time launching the VM, run the following commands to ensure that the setup script is executed every time you open a new terminal.
$ echo "source /opt/ros/noetic/setup.bash" >> ~/.bashrc
$ source ~/.bashrc
You can check that the setup script has been executed by running the roscore command in a terminal
window. You should see an output that looks like the following:
... logging to ~/.ros/log/9cf88ce4-b14d-11df-8a75-00251148e8cf/roslaunch-machine_name-13039.log
Checking log directory for disk usage. This may take awhile.
Press Ctrl-C to interrupt
Done checking log file disk usage. Usage is <1GB.
started roslaunch server http://machine_name:33919/
ros_comm version 1.15.8
SUMMARY
======
PARAMETERS
* /rosdistro: noetic
* /rosversion: 1.15.8
NODES
auto-starting new master
process[master]: started with pid [13054]
ROS_MASTER_URI=http://machine_name:11311/
setting /run_id to 9cf88ce4-b14d-11df-8a75-00251148e8cf
process[rosout-1]: started with pid [13067]
started core service [/rosout]
You might see one of the following two errors:
bash: roscore: command not found
WARNING: unable to configure logging. No log files will be generated
Checking log directory for disk usage. This may take awhile.
Press Ctrl-C to interrupt
Done checking log file disk usage. Usage is <1GB.
Resource not found: roslaunch
The traceback for the exception was written to the log file
Traceback (most recent call last):
File "/usr/lib/python3/dist-packages/roslaunch/__init__.py", line 322, in main
p.start()
File "/usr/lib/python3/dist-packages/roslaunch/parent.py", line 277, in start
self._start_infrastructure()
File "/usr/lib/python3/dist-packages/roslaunch/parent.py", line 226, in _start_infrastructure
self._load_config()
File "/usr/lib/python3/dist-packages/roslaunch/parent.py", line 137, in _load_config
self.config = roslaunch.config.load_config_default(self.roslaunch_files, self.port,
File "/usr/lib/python3/dist-packages/roslaunch/config.py", line 447, in load_config_default
load_roscore(loader, config, verbose=verbose)
File "/usr/lib/python3/dist-packages/roslaunch/config.py", line 92, in load_roscore
f_roscore = get_roscore_filename()
File "/usr/lib/python3/dist-packages/roslaunch/config.py", line 84, in get_roscore_filename
return os.path.join(r.get_path('roslaunch'), 'resources', 'roscore.xml')
File "/usr/lib/python3/dist-packages/rospkg/rospack.py", line 207, in get_path
raise ResourceNotFound(name, ros_paths=self._ros_paths)
rospkg.common.ResourceNotFound: roslaunch
If you do see one of these two errors or are otherwise unable to run roscore, re-run the commands to automatically execute the setup script:
$ echo "source /opt/ros/noetic/setup.bash" >> ~/.bashrc
$ source ~/.bashrc
Now, you should be able to run roscore and it should show the correct output.
If you are still not seeing the correct output when you run roscore, please reach out to the teaching team for help by posting in the #computer-setup-help channel in our course Slack.
We give a BIG thank you to Colin Hudler and UChicago CS techstaff for their help and support in setting up the VM as well as their ongoing support for ensuring that each student in the class get a working programming environment for Intro Robotics. We also thank Borja Sotomayor for sharing the instructions he and his team developed for setting up a UTM VM for M1 Macs.