Note All the commands in this file are run in a command shell. We've therefore excluded the traditional $
prompt on all lines to make copy-paste a bit easier.
1. Install ROS Melodic. See the wiki for more details
a) Add ROS to the apt sources list:
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://ha.pool.sks-keyservers.net:80 --recv-key 421C365BD9FF1F717815A3895523BAEEB01FA116
b) Install ROS
sudo apt update
sudo apt install ros-melodic-desktop-full
c) Initialize rosdep
sudo rosdep init
rosdep update
d) Source the ROS environment
echo "source /opt/ros/melodic/setup.bash" >> ~/.bashrc
2. Install catkin_tools
We recommend using catkin_tools
rather than catkin_make
, as it makes switching between native and cross compilation easier.
The instructions and scripts discussed below are all for catkin_tools
.
sudo apt install python-catkin-tools
mkdir -p ~/robot_workspace/src
cd ~/robot_workspace
catkin init
cd ~/robot_workspace/src
git clone https://github.com/uwreact/frc_control.git
This is a tricky procedure, and these instructions aren't guaranteed to work forever. However, the general procedure will largely remain the same. See the ROS wiki for more information.
Download the latest Linux release from the WPILib GitHub (At the time of writing, the latest is 2019.2.1). Extract the archive to ~/frc2019
.
wget https://github.com/wpilibsuite/allwpilib/releases/download/v2019.2.1/WPILib_Linux-2019.2.1.tar.gz
mkdir ~/frc2019
tar xzf WPILib_Linux-2019.2.1.tar.gz -C ~/frc2019
rm WPILib_Linux-2019.2.1.tar.gz
mkdir ~/ros_arm_cross_ws
cd ~/ros_arm_cross_ws
This list of packages may change as time goes on. Right now, the standard robot set of packages contains many unneeded packages and adds a lot of unnecessary dependencies. Once development of this project proceeds further, we can further customize this as required. In fact, we might consider only installing the dependencies of frc_control with no additional packages. This does mean that teams who wish to run their whole ROS stack on the RIO (Instead of the recommended config; frc_control on the RIO, everything else on other machines) will be required to either manually install their extra dependencies, or clone them into their workspace. Needs some consideration.
sudo apt install python-rosinstall-generator python-wstool
rosinstall_generator robot ros_control ros_controllers --exclude rqt_joint_trajectory_controller gazebo_ros --rosdistro melodic --deps --wet-only --tar > melodic-roborio-wet.rosinstall
wstool init -j8 src melodic-roborio-wet.rosinstall
When possible, we install ipks that NI has distributed for the RoboRIO. If these aren't available, we instead compile libraries from source. Note: The order of installation is important, as some of these packages are dependent on eachother
cd ~/robot_workspace/src/frc_control
./scripts/installation/install_cross_deps_ipks.bash
./scripts/installation/install_cross_deps_src.bash
In order to successfully cross-compile ROS, we must use a fresh shell that doesn't have a ROS environment sourced.
You can do this manually by commenting out source /opt/ros/melodic/setup.bash
from your ~/.bashrc
, opening a new terminal,
performing the installation steps required, and restoring that line once you are complete. Or, you can use the following script:
cd ~/robot_workspace/src/frc_control
source scripts/installation/unsource_ros.bash
cd ~/ros_arm_cross_ws
rm -rf ~/frc2019/roborio/arm-frc2019-linux-gnueabi/opt/ros/melodic devel_isolated build_isolated
./src/catkin/bin/catkin_make_isolated --install --install-space ~/frc2019/roborio/arm-frc2019-linux-gnueabi/opt/ros/melodic -DCMAKE_TOOLCHAIN_FILE=~/robot_workspace/src/frc_control/rostoolchain.cmake -DCMAKE_MODULE_PATH=$HOME/frc2019/roborio/arm-frc2019-linux-gnueabi/usr/share/cmake/Modules -DCATKIN_ENABLE_TESTING=0
cd ~/robot_workspace
./src/frc_control/scripts/installation/setup_catkin.bash .
catkin build --profile native
catkin build --profile cross
frc_control has built-in support for the most common 3rd party libraries; CTRE Toolsuite, Kauai Labs, and Mindsensors. However, since we know not all teams will be using all of these libraries, they are all disabled by default. To download and enable these libraries, use the install_3rd_party_libs.py
script.
cd ~/robot_workspace/src/frc_control/scripts/installation
./install_3rd_party_libs.py --all
Follow the standard instructions to flash the roboRIO with the roboRIO Imaging Tool Instructions here. Note that this requires a Windows PC and access to the NI FRC Update Suite.
Use the upload_ros.sh
script to upload and install ROS on the RIO.
You must specify the team number.
cd ~/robot_workspace/src/frc_control/scripts
./upload_ros.sh 1234
Use the upload_frc_control.sh
script to upload and install your user code to the RIO.
You must specify the team number.
You should also specify the launch file to be run on bootup - By default, this is frc_robot_hw bringup.launch
, but you may customize it to whatever launch file is appropriate for your system.
cd ~/robot_workspace/src/frc_control/scripts
./upload_frc_control.sh 1234 frc_robot_hw bringup.launch