Table of Contents
How to Setup Robotino for Programming and Navigation
Author: Dylan Wallace Email: wallad3@unlv.nevada.edu
Date: Last modified on 06/24/16
Keywords: step-by-step, how to, ssh, linux, Robotino, ROS, programming, navigation
The big picture problem is navigation and mapping for robots. Solving this partially or completely is important because it allows for autonomous systems to navigate around autonomously, giving much more power than human control. This tutorial shows you how to setup and generally operate Robotino and takes approximately 1-2 hours to complete.
Motivation and Audience
This tutorial's motivation is to provide a platform to build navigation and mapping programs off of. Readers of this tutorial assumes the reader has the following background and interests:
* Know how to program in linux and C++
* Knowledge in ROS is also very helpful for these tutorials
* Perhaps also know how to ssh and use ftp
* Perhaps additional background needed may include interest in mapping and navigation algorithms
* This tutorial may also attract readers who want to work with other linux-0based systems such as Darwin or MKII
For information on ROS, please refer to this document: https://cse.sc.edu/~jokane/agitr/
For information on Linux, please refer to this webpage: http://www.ee.surrey.ac.uk/Teaching/Unix/
For information on c++, please refer to this webpage: http://www.cplusplus.com/doc/tutorial/
For information on navigation and mapping methods, refer to this internal tutorial: http://daslhub.org/unlv/wiki/doku.php?id=breadth-first_search_and_depth-first_search
The rest of this tutorial is presented as follows:
Setup Operation Final Words
Before starting this tutorials you must have cmake 3.0 and ccmake installed onto your Ubuntu computer
For more information on upgrading your version of cmake to 3.x, see This link.
Setup
This section gives step-by-step instructions along with photos to setup Robotino for programming and mapping.
Step 1: Boot up Robotino
Power on Robotino to ensure all systems are working properly. Either connect Robotino to a 24V, 2.5A power supply, or connect two 12V batteries into the two battery slots provided on Robotino. Make sure to read through the Robotino operation manual before plugging anything in, and always make sure to use the proper safety precautions. Provided below are photos of how to hook up the power supply or batteries. Verify thqat
Step 2: Setup DHCP on Robotino
Do this by accessing Robotino's menu with the buttons on its top side. Press Enter and navigate down to Network. After network navigate to eth0, and then DHCP. Once in the DHCP menu, scroll down to Activate and press Enter. This will setup Robotino with a static IP that is constantly accessible. For my Robotino setup, this IP is 10.42.0.75, but your mileage may vary.
Step 3: Backup Robotino Data
For this section of the tutorial you will need to locate or buy an additional CF card in order to make a copy of the current image on Robotino's memory. Additionally, you will need an adapter or card reader for reading CF cards on your computer. If you do not have a CF card, I advise buying a cheaper SD card, and using a CF adapter. Once you have acquired the spare CF card and the adapter, power down Robotino and remove all power sources. Remove the CF card from Robotino (it is located right under the USB ports on the top section), and plug in the card to the adapter. In linux, open up a terminal and type the following:
sudo dd if=/dev/<CF card disk>/ of=~/<your desired path on your computer>/RobotinoBackup<date>.iso
Replace <CF card disk> with the name of the CF card's disk (either sdb, sda, sdc, sdd. Do not chose something that has a number like sdb1, as this is only the partition and not the entire disk). Replace <your desired path on your computer> with wherever you want to store this image for use. For example my path would be ~/Robotino/setup/. Additionally, replace the <date> with whatever the month, day, and year it is for the time that you are copying this over. This is to distinguish this file from any other backups created.
Once it has successfuly copied over the information from the card, eject the card in the file system, and then remove the card form the adapter. Now plug in your other media, whether it be an SD card or another CF card, into the adapter for your computer. We will be using a similar command for this process as before, but be careful because it is not exactly the same. This time, type:
sudo dd if=~/<your path from earlier>/RobotinoBackup<date>.iso of=/dev/<media disk name>
Again make sure you replace <your path from earlier> with the path that you copied the original CF card information over from, and replace <date> with whatever date you listed for the backup file. This time, replace the <media disk name> with whatever comes up as the name of the disk (again this will be either sda, sdb, sdc, sdd, etc.).
Once this has finished successfully copying over, you are good to go with plugging in either media card, as they will be identical. Use one as a constant backup, so that you will always have a version to go back to if you mess up somewhere.
After taking these steps, you may still want to go through another backup process to make sure you have access to all of Robotino's old files in case they get corrupted. The best way to do this is by using an ftp service such as filezilla. Open up your ftp service, and login to a booted up and connected robotino with the following information: Host:<robotino_ip> , Username: robotino , Password: robotino , Port: 22 .
Once successfully connected, select all of the files from Robotino's drive, and copy it over to a folder on your computer from within the ftp service. This can be used with simple drag and drop in programs like filezilla. Once you have completed this step, you have successfully backed up all important data, and you can begin working on seting up the software for Robotino.
Step 4: SSH into Robotino
Start by opening up a terminal window in Linux. In order to SSH into Robotino you will need to be connected to Robotino with a network cable. Also make sure that you are connected to the Robotino wireless connection in Linux. You can do this by simply going to your network settings in Ubuntu and connecting to the wireless network that you are using for Robotino. Now you can go back to your terminal and type the following (replace <your_robotino_ip> with the ip address setup during Step 2):
ssh robotino@<your_robotino_ip>
When prompted for a password, type “robotino”.
You are also going to want to login as root in a separate terminal. To do this, open up another terminal, and type in the following:
ssh root@<your_robotino_ip>
The password for this root user is “dorp6”.
Step 5: Download and Setup ROS
For information on installing ROS for your PC, refer to this tutorial (if running Ubuntu 14.04): http://wiki.ros.org/indigo/Installation/Ubuntu. You will want to install at least ROS Hydro, as we will be using catkin to build our ROS packages. Indigo is the ROS version that I chose to best suit my need on 14.04 with Robotino.
If you are running a different distro, please refer to: http://wiki.ros.org/ROS/Installation
After ROS is installed, you will want to setup your catkin workspace. Do this by entering the following commands:
mkdir -p ~/catkin_ws/src cd ~/catkin_ws/src catkin_init_workspace cd ../ catkin_make echo "source ~/catkin_ws/devel/setup.bash" >> ~/.bashrc source ~/.bashrc
Step 6: Install the Robotino API2
Follow this tutorial for setting up the API2 files onto your computer: http://wiki.openrobotino.org/index.php?title=API2_source_build.
After setting up the API on your computer, you will need to intall the API onto Robotino. Begin by opening up the root ssh terminal for Robotino. In this terminal, enter the following:
echo "echo "deb http://doc.openrobotino.org/download/packages/i386 ./" >> /etc/apt/sources.list vim /etc/apt/sources.list
After the last command, the sources.list file will pop-up in vim, and you should check at the bottom of the file to make sure that the Robotino API source was added. Once that is confirmed, quit vim by pressing <esc> and then “:q”. now, in the root terminal still, enter the following:
apt-get update apt-get install robotino-api2 robotino-examples
Step 7: Download and Setup the ROS packages for Robotino
Due to outdated revisions to the Robotino sources, the existing tutorials for setting up the ROS packages no longer work properly. Here I will explain the necessary steps to go around this problem. First you will want to install the necessary daemons. First open up a terminal on your computer, and enter the following commands one after another (replace the * with the most current version listed here):
wget http://doc.openrobotino.org/download/packages/i386/rec-rpc-qt4.5.0_*_i386.deb wget http://doc.openrobotino.org/download/packages/i386/robotino-common_*_i386.deb wget http://doc.openrobotino.org/download/packages/i386/robotino_daemons_*_i386.deb wget http://doc.openrobotino.org/download/packages/i386/robotino-api2_*_i386.deb wget http://doc.openrobotino.org/download/packages/i386/robotino-examples_*_i386.deb
After these packages are downloaded, you will want to transfer them over to Robotino. We can achieve this using a similar ftp service such as what was used previously to backup the data on Robotino. Refer to the 3rd step for more information on this process. Once the files are transferred to Robotino, you will want to unpackage and install the files onto Robotino. Go into your Robotino ssh terminal, and enter the following commands (again replace the * with the version you downloaded to your computer):
dpkg -i rec-rpc-qt4.5.0_*_i386.deb dpkg -i robotino-common_*_i386.deb dpkg -i --auto-deconfigure robotino-daemons_*_i386.deb dpkg -i robotino-api2_*_i386.deb dpkg -i robotino-examples_*_i386.deb
After these succeed installing, you can now focus on getting the Robotino ROS packages setup onto your computer. First, you will want to open up a fresh terminal and navigate into your catkin workspace. This should be located in your home directory. Then navigate to the src folder. When you are there your directory should be ~/catkin_ws/src . Once here you will want to type the following into your terminal:
svn co http://svn.openrobotino.org/robotino-ros-pkg/trunk/catkin-pkg/ cd catkin-pkg svn up -r3621
This will ensure that you collect the correct version from the depository, and not the newer, broken versions. After this you are able to build these packages. Navigate back to your workspace (~/catkin_ws/). Enter the following in order to build the packages:
rosdep install robotino_node catkin_make
If this goes smoothly without any errors, then you will be good to go! If not, you will need to debug this issue to figure out what is causing the packages to build improperly. If you need any help with debugging this feel free to email me. After this is finished, Robotino should be all setup and ready to be programmed!
Operation
Step 1: Boot up Robotino
Power on Robotino to ensure all systems are working properly. Either connect Robotino to a 24V, 2.5A power supply, or connect two 12V batteries into the two battery slots provided on Robotino. Make sure to read through the Robotino operation manual before plugging anything in, and always make sure to use the proper safety precautions. Provided below are photos of how to hook up the power supply or batteries. Verify that
Step 2: Setup DHCP on Robotino
Do this by accessing Robotino's menu with the buttons on its top side. Press Enter and navigate down to Network. After network navigate to eth0, and then DHCP. Once in the DHCP menu, scroll down to Activate and press Enter. This will setup Robotino with a static IP that is constantly accessible. For my Robotino setup, this IP is 10.42.0.75, but your mileage may vary.
Step 4: SSH into Robotino
Start by opening up a terminal window in Linux. In order to SSH into Robotino you will need to be connected to Robotino with a network cable. Also make sure that you are connected to the Robotino wireless connection in Linux. You can do this by simply going to your network settings in Ubuntu and connecting to the wireless network that you are using for Robotino. Now you can go back to your terminal and type the following (replace <your_robotino_ip> with the ip address setup during Step 2):
ssh robotino@<your_robotino_ip>
When prompted for a password, type “robotino”.
You are also going to want to login as root in a separate terminal. To do this, open up another terminal, and type in the following:
ssh root@<your_robotino_ip>
The password for this root user is “dorp6”.
Step 5: Run your Program
Refer to the specific tutorial page for the instructions specific to the program that you are attempting to run on Robotino. For example, here are the commands used to launch the Breadth-First Navigation program from this tutorial.
Once you have powered on and configured DHCP on Robotino after setup is complete, make sure that you download the BFNav ROS package to your catkin workspace src folder, and run catkin_make. Once this has built correctly, open a terminal and type the following:
roslaunch robotino_node robotino_node.launch hostname:=<robotinoIP>
Now open a second terminal and type the following:
rosrun robotino_control_bfnav BFNavigatorNode
Now the BFNav program should run successfully. Please note that the configuration of the obstacles and the grid is detailed in the BFNavigator Node file, and can be edited for your use there. The current configuration given is using the map given at the very beginning of the tutorial.
Final Words
This tutorial's objective was to guide a user through setting up Robotino for programming, and then being able to run programs on Robotino. Once the concepts were conveyed the reader could run any test programs on Robotino, and hopefully run their own programs on Robotino after other programming tutorails.
Speculating future work derived from this tutorial, includes implementing BFS, DFS, and other navigation methods on Robotino. In the big picture, the problem of robotic localization and navigation can be solved with this tutorial and its future work.
For questions, clarifications, etc, Email: wallad3@unlv.nevada.edu