Difference between revisions of "Cognitive Robotics - Software Installation Guide"
(→VirtualBox Setup) |
(→Accessing Physical Devices) |
||
(49 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
− | |||
− | |||
__TOC__ | __TOC__ | ||
This page provides a step-by-step guide to installing the tools, utilities, and example software for [http://vernon.eu/cognitive_robotics/index.htm Cognitive Robotics] using Ubuntu 18.04, ROS Melodic, and the CRAM cognitive architecture. | This page provides a step-by-step guide to installing the tools, utilities, and example software for [http://vernon.eu/cognitive_robotics/index.htm Cognitive Robotics] using Ubuntu 18.04, ROS Melodic, and the CRAM cognitive architecture. | ||
<span style="color:#FF0000">Please follow these instructions exactly as they are stated.</span> | <span style="color:#FF0000">Please follow these instructions exactly as they are stated.</span> | ||
+ | |||
Do not be tempted to skip through them, assuming that you will be able to figure it out yourself. You might, but it is more likely you will miss something small but important and it won't work as required. Take your time, follow these instructions carefully, and everything will work. | Do not be tempted to skip through them, assuming that you will be able to figure it out yourself. You might, but it is more likely you will miss something small but important and it won't work as required. Take your time, follow these instructions carefully, and everything will work. | ||
− | + | In the past, there were two options: | |
− | + | ||
* Option A: install the VirtualBox Ubuntu 18.04 virtual machine (VM) with everything pre-installed. | * Option A: install the VirtualBox Ubuntu 18.04 virtual machine (VM) with everything pre-installed. | ||
* Option B: install all the required tools and utilities directly on a computer running Ubuntu 18.04. | * Option B: install all the required tools and utilities directly on a computer running Ubuntu 18.04. | ||
− | + | However, the recommended setup for CRAM is now Ubuntu 20.04 with ROS Noetic and, unfortunately, the material in this course no longer works correctly with this configuration. | |
+ | |||
+ | The [https://cram-system.org/installation CRAM installation] page still has instructions for installing with Ubuntu 18.04 with ROS Melodic but it is unclear how long this will be supported. Apparently, support for the Lisp version of CRAM, which is what this course uses, has been discontinued. | ||
+ | For that reason, we restrict ourselves here to Option A. | ||
Line 29: | Line 30: | ||
− | Double click on the downloaded file (<code>VirtualBox-7.0. | + | Double click on the downloaded file (<code>VirtualBox-7.0.18-162988-Win.exe</code> at time of writing) and follow the instructions. |
=== MacOS === | === MacOS === | ||
Line 43: | Line 44: | ||
== Install the VirtualBox Extension Pack == | == Install the VirtualBox Extension Pack == | ||
− | Select <span style="color:#0000AA">All supported platforms</span> to download the VirtualBox Extension Pack. This is needed to provide access to USB devices such as the Lynxmotion AL5D robot manipulator, iRobot Create 2 mobile robot, and webcams. | + | Select <span style="color:#0000AA">All supported platforms</span> on the [https://www.virtualbox.org/wiki/Downloads VirtualBox Download page] to download the VirtualBox Extension Pack. This is needed to provide access to USB devices such as the Lynxmotion AL5D robot manipulator, iRobot Create 2 mobile robot, and webcams. |
− | Double click on the downloaded file (<code>Oracle_VM_VirtualBox_Extension_Pack-7.0. | + | Double click on the downloaded file (<code>Oracle_VM_VirtualBox_Extension_Pack-7.0.18.vbox-extpack</code> at time of writing) and follow the instructions. |
Line 53: | Line 54: | ||
'''Step 1: Copy the Virtual Disk Image''' | '''Step 1: Copy the Virtual Disk Image''' | ||
− | The virtual disk image <code>cram-vm.vdi</code> contains a VirtualBox virtual machine with Ubuntu 18.04, ROS Melodic, and example code pre-installed. It will be distributed | + | The virtual disk image <code>cram-vm.vdi</code> contains a VirtualBox virtual machine with Ubuntu 18.04, ROS Melodic, and example code pre-installed. It will be distributed on a physical disk. Copy it to some convenient, easily-identified folder. |
Line 64: | Line 65: | ||
− | If a window with the guided menu open, change to expert mode | + | If a window with the guided menu open, change to expert mode. |
− | '''Step 3: | + | '''Step 3: Create and configure the virtual machine''' |
If it's not already open, click the Name and Operating System tab | If it's not already open, click the Name and Operating System tab | ||
Line 91: | Line 92: | ||
[[File:VirtualBox_Configuration_4.png]] | [[File:VirtualBox_Configuration_4.png]] | ||
− | + | In the window that pops up, click '''Add''' | |
[[File:VirtualBox_Configuration_5.png]] | [[File:VirtualBox_Configuration_5.png]] | ||
− | Browse to where you stored the cram-vm.vdi file, select it, and click Open | + | Browse to where you stored the cram-vm.vdi file, select it, and click '''Open''' |
[[File:VirtualBox_Configuration_6.png]] | [[File:VirtualBox_Configuration_6.png]] | ||
Line 108: | Line 109: | ||
− | '''Step 4: | + | '''Step 4: Enable USB devices''' |
Choose the newly created virtual machine and click on '''Settings'''. | Choose the newly created virtual machine and click on '''Settings'''. | ||
− | [[File: | + | [[File:VirtualBox_Configuration_9.png]] |
− | Click on ''' | + | * Click on '''Ports'''. |
+ | * Click on '''USB''' and select '''USB 2.0'''. | ||
+ | * Choose the device you want to add from the list by clicking the connector icon with the green cross at the right hand side. | ||
− | [[File: | + | [[File:VirtualBox_Configuration_6.jpg]] |
− | + | Notice that none of the devices you want to add, e.g., Lynxmotion AL5D robot manipulator, are in the list. | |
− | + | ||
− | + | ||
+ | This is because the device needs to be connected before it can be added. | ||
− | + | Here is what you would see if the iRobot Create 2 mobile robot was connected. | |
− | + | [[File:VirtualBox_Configuration_7.jpg]] | |
− | + | For now, just add your webcam and remember to return to this step when you want to use any USB device later in the course, e.g., an external webcam, the Lynxmotion AL5D robot manipulator, or the iRobot Create 2 mobile robot. | |
The device for the Lynxmotion AL5D robot manipulator is <code>FTDI FT232R USB UART [0600]</code>. | The device for the Lynxmotion AL5D robot manipulator is <code>FTDI FT232R USB UART [0600]</code>. | ||
Line 145: | Line 147: | ||
− | '''Step | + | '''Step 5: Enable Host OS to Guest OS Copy and Paste''' |
− | When doing exercises and assignments, you may wish to copy text from the host OS (Windows | + | When doing exercises and assignments, you may wish to copy text from the host OS (Windows 11, probably) and paste it to the guest OS (Ubuntu 18.04). Note that pasting to the terminal is <code><shift> <ctrl> v </code> not <code> <ctrl> v</code>. |
− | + | To do this, we need to enable Shared Clipboard and Drag’n’Drop functionality between Guest and Host Machine. | |
− | + | To enable Host OS to Guest OS Copy and Paste, Guest Additions must be installed in the virtual machine. This has already been done in the <code>cram-vm</code> virtual machine. | |
+ | Power off your Ubuntu guest OS. | ||
− | + | Choose the <code>cram-vm</code> virtual machine and click on '''Settings'''. | |
+ | Click on '''General''' and '''Advanced''' and select '''Shared Clipboard''' and choose the '''Bidirectional''' option. | ||
− | + | Select '''Shared Drag 'n' Drop''' and choose the '''Bidirectional''' option. | |
− | + | [[File:Install-Virtualbox-Guest-Additions_2.jpg]] | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | [[File:Install-Virtualbox-Guest-Additions_2. | + | |
Line 180: | Line 179: | ||
Everything is set up and the virtual machine can now be started. When Ubuntu 18.04 boots, enter the password <code>cram</code>, if asked. | Everything is set up and the virtual machine can now be started. When Ubuntu 18.04 boots, enter the password <code>cram</code>, if asked. | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
+ | <!-- | ||
+ | = Option B: Install Required Tools and Utilities on a Computer running Ubuntu 20.04 = | ||
− | |||
+ | == Install ROS Noetic == | ||
If a terminal is not already open, open one by typing <code>ctrl-alt-t</code>. | If a terminal is not already open, open one by typing <code>ctrl-alt-t</code>. | ||
− | Copy and paste the installation commands | + | Copy and paste the installation commands below to the terminal and execute them by entering <code>return</code>. |
− | Note | + | Note: to copy from the browser use by <code>ctrl-c</code> or <code>cmd-c</code>. However, to paste them to the terminal use <code>shift-ctrl-v</code> (or right click and select paste). |
+ | 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 install curl | ||
+ | curl -s https://raw.githubusercontent.com/ros/rosdistro/master/ros.asc | sudo apt-key add - | ||
+ | sudo apt update | ||
+ | sudo apt install ros-noetic-desktop | ||
+ | source /opt/ros/noetic/setup.bash | ||
+ | echo "source /opt/ros/noetic/setup.bash" >> ~/.bashrc | ||
+ | source ~/.bashrc | ||
+ | sudo apt install python3-rosdep python3-rosinstall python3-rosinstall-generator python3-wstool build-essential | ||
+ | sudo apt install python3-rosdep | ||
+ | sudo rosdep init | ||
+ | rosdep update | ||
− | |||
− | |||
− | + | == Install the Example Programs ROS Meta Package == | |
− | + | This meta package comprises ROS packages for Modules 2, 3, 4, and 5 (module2, module3, module4, and module5, respectively). | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | This | + | |
− | + | ||
− | + | ||
− | + | ||
If a terminal is not already open, open one by typing <code>ctrl-alt-t</code>. | If a terminal is not already open, open one by typing <code>ctrl-alt-t</code>. | ||
− | Copy and paste the installation commands | + | Copy and paste the installation commands below to the terminal and execute them by entering <code>return</code>. |
− | + | sudo apt-get install libncurses-dev # for module 5 | |
+ | roscd | ||
+ | cd ../src | ||
+ | git clone https://github.com/cognitive-robotics-course/coro_examples.git | ||
+ | cd .. | ||
+ | sudo apt-get update | ||
+ | catkin_make | ||
− | |||
+ | == Install CRAM == | ||
+ | Also see https://github.com/cram2/cram/blob/devel/README.md | ||
− | + | === Set up an SSH key for your GitHub account === | |
+ | See the following for instructions on how to do this. | ||
+ | https://docs.github.com/en/authentication/connecting-to-github-with-ssh/generating-a-new-ssh-key-and-adding-it-to-the-ssh-agent | ||
+ | https://docs.github.com/en/authentication/connecting-to-github-with-ssh/adding-a-new-ssh-key-to-your-github-account | ||
− | + | Now do the following. | |
− | + | sudo apt install ros-noetic-roslisp-repl | |
− | + | sudo apt-get install python3-rosinstall python3-wstool | |
− | + | ||
− | + | cd ~/workspace/ros/src | |
− | + | wstool init | |
− | + | wstool merge https://raw.githubusercontent.com/cram2/cram/devel/cram-20.04.rosinstall | |
− | + | wstool update | |
− | + | ||
− | + | cd ~/workspace/ros | |
− | + | ||
− | + | rosdep update | |
− | + | rosdep install --ignore-src --from-paths src/ -r | |
− | + | ||
− | + | catkin_make | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
+ | --> | ||
= Accessing Physical Devices = | = Accessing Physical Devices = | ||
− | For completeness, here are the instructions to access the iRobot Create 2 mobile robot and the Lynxmotion AL5D robot manipulator. Instructions for a USB camera will be added later. You can carry out these instructions when you have access to the robots and cameras in the lab. | + | For completeness, here are the instructions to access <!-- the iRobot Create 2 mobile robot and--> the Lynxmotion AL5D robot manipulator. Instructions for a USB camera will be added later. You can carry out these instructions when you have access to the robots and cameras in the lab. |
− | + | ||
− | If you are using the <code> | + | If you are using the <code>cram-vm</code> VM, don't forget to enable access to the USB ports; see Step 4 of [[#VirtualBox Setup | VirtualBox Setup]] in Option A above. |
+ | <!-- | ||
== Setup the Connection to the iRobot Create 2 Mobile Robot == | == Setup the Connection to the iRobot Create 2 Mobile Robot == | ||
Line 344: | Line 293: | ||
rostopic pub -r 10 /cmd_vel geometry_msgs/Twist '{linear: {x: 0.1, y: 0.0, z: 0.0}, angular: {x: 0.0,y: 0.0,z: 0.0}}' | rostopic pub -r 10 /cmd_vel geometry_msgs/Twist '{linear: {x: 0.1, y: 0.0, z: 0.0}, angular: {x: 0.0,y: 0.0,z: 0.0}}' | ||
− | 5. Trouble shooting: if the robot does not move, do the following (recall that the superuser password is | + | 5. Trouble shooting: if the robot does not move, do the following (recall that the superuser password is cram). |
− | sudo usermod -a -G dialout | + | sudo usermod -a -G dialout cram |
* Power down the virtual machine (or PC if you are running Ubuntu natively) and power it back up again for the permissions to take effect. | * Power down the virtual machine (or PC if you are running Ubuntu natively) and power it back up again for the permissions to take effect. | ||
Line 354: | Line 303: | ||
dmesg | grep -i FTDI | dmesg | grep -i FTDI | ||
− | * If are using the <code> | + | * If are using the <code>cram-vm</code> virtual machine and your host operating system is Ubuntu, you should also enter the following in a terminal of your host machine and then restart the virtual machine: |
$ sudo adduser $USER vboxsf | $ sudo adduser $USER vboxsf | ||
* If the virtual machine displays blank black screen, try pressing CTRL + F on your keyboard. It should then display the content. | * If the virtual machine displays blank black screen, try pressing CTRL + F on your keyboard. It should then display the content. | ||
+ | |||
+ | --> | ||
== Setup the Connection to the Lynxmotion AL5D Robot Manipulator == | == Setup the Connection to the Lynxmotion AL5D Robot Manipulator == | ||
Line 366: | Line 317: | ||
2. Connect your laptop to the robot controller using the USB cable. | 2. Connect your laptop to the robot controller using the USB cable. | ||
− | 3. If you are using the <code> | + | 3. If you are using the <code>cram-vm</code> VM, add the robot controller USB device to the list of registered USB devices by following the instructions in Step 5: Enable USB Devices of [[#VirtualBox Setup | VirtualBox Setup]] in Option A above. |
− | |||
− | |||
− | |||
− | |||
4. Check that everything is working, as follows. | 4. Check that everything is working, as follows. | ||
Line 378: | Line 325: | ||
echo "#0P1610S250" > "/dev/ttyUSB0" % setpoint 1610 for joint 0 at speed 250 | echo "#0P1610S250" > "/dev/ttyUSB0" % setpoint 1610 for joint 0 at speed 250 | ||
− | 5.Trouble shooting: if the robot does not move, do the following (recall that the superuser password is | + | 5.Trouble shooting: if the robot does not move, do the following (recall that the superuser password is cram). |
− | sudo usermod -a -G dialout | + | sudo usermod -a -G dialout cram |
* Power down the virtual machine (or PC if you are running Ubuntu natively) and power it back up again for the permissions to take effect. | * Power down the virtual machine (or PC if you are running Ubuntu natively) and power it back up again for the permissions to take effect. | ||
Line 388: | Line 335: | ||
dmesg | grep -i FTDI | dmesg | grep -i FTDI | ||
− | * If are using the <code> | + | * If are using the <code>cram-vm</code> virtual machine and your host operating system is Ubuntu, you should also enter the following in a terminal of your host machine and then restart the virtual machine: |
$ sudo adduser $USER vboxsf | $ sudo adduser $USER vboxsf | ||
Line 395: | Line 342: | ||
* If the virtual machine displays blank black screen, try pressing CTRL + F on your keyboard. It should then display the content. | * If the virtual machine displays blank black screen, try pressing CTRL + F on your keyboard. It should then display the content. | ||
− | |||
− | |||
− | |||
− |
Latest revision as of 04:17, 9 August 2024
Contents
This page provides a step-by-step guide to installing the tools, utilities, and example software for Cognitive Robotics using Ubuntu 18.04, ROS Melodic, and the CRAM cognitive architecture.
Please follow these instructions exactly as they are stated.
Do not be tempted to skip through them, assuming that you will be able to figure it out yourself. You might, but it is more likely you will miss something small but important and it won't work as required. Take your time, follow these instructions carefully, and everything will work.
In the past, there were two options:
- Option A: install the VirtualBox Ubuntu 18.04 virtual machine (VM) with everything pre-installed.
- Option B: install all the required tools and utilities directly on a computer running Ubuntu 18.04.
However, the recommended setup for CRAM is now Ubuntu 20.04 with ROS Noetic and, unfortunately, the material in this course no longer works correctly with this configuration.
The CRAM installation page still has instructions for installing with Ubuntu 18.04 with ROS Melodic but it is unclear how long this will be supported. Apparently, support for the Lisp version of CRAM, which is what this course uses, has been discontinued.
For that reason, we restrict ourselves here to Option A.
Option A: Install the VirtualBox Ubuntu 18.04 Virtual Machine
Install VirtualBox
There follows instructions for Windows, Mac OS, and Ubuntu (in case you already have Ubuntu but want to use the VM instead of installing all the required tools and utilities).
Windows
Open the VirtualBox Download page at https://www.virtualbox.org/wiki/Downloads and select Windows hosts to download the installation file.
Double click on the downloaded file (VirtualBox-7.0.18-162988-Win.exe
at time of writing) and follow the instructions.
MacOS
Download the .dmg installer for OS X systems, execute the file and follow the instructions.
If the VirtualBox installer fails as it is completing the installation, it is probably a problem with a security setting. Go to System Preferences > Security & Privacy. Click the lock to make changes (if necessary). Click the Allow button at the bottom and re-run the installer.
Ubuntu Linux
You can install VirtualBox via the Ubuntu Software Center or through command line as follows.
sudo apt update sudo apt install virtualbox
Install the VirtualBox Extension Pack
Select All supported platforms on the VirtualBox Download page to download the VirtualBox Extension Pack. This is needed to provide access to USB devices such as the Lynxmotion AL5D robot manipulator, iRobot Create 2 mobile robot, and webcams.
Double click on the downloaded file (Oracle_VM_VirtualBox_Extension_Pack-7.0.18.vbox-extpack
at time of writing) and follow the instructions.
VirtualBox Setup
Step 1: Copy the Virtual Disk Image
The virtual disk image cram-vm.vdi
contains a VirtualBox virtual machine with Ubuntu 18.04, ROS Melodic, and example code pre-installed. It will be distributed on a physical disk. Copy it to some convenient, easily-identified folder.
Step 2: Launch VirtualBox
In VirtualBox, you first need to create a new virtual machine. Click on the New button.
If a window with the guided menu open, change to expert mode.
Step 3: Create and configure the virtual machine
If it's not already open, click the Name and Operating System tab
- Set the name to cram-vm
- Select Linux for the operating system type
- Select Ubuntu (64-bit) for the operating system version
Click the Hardware tab.
- Set the VM's memory size (RAM); choose 4096 MB or more if your PC's capacity allows. We set it to 16384 MB in the screenshot
- Set the number of processors to use. We set it to 4 in the screenshot.
Click the Hard Disk Tab
- Select Use an Existing Virtual Hard Disk File
- Using the button on the right, open the file explorer
In the window that pops up, click Add
Browse to where you stored the cram-vm.vdi file, select it, and click Open
Click Choose
Finally, click Finish
Step 4: Enable USB devices
Choose the newly created virtual machine and click on Settings.
- Click on Ports.
- Click on USB and select USB 2.0.
- Choose the device you want to add from the list by clicking the connector icon with the green cross at the right hand side.
Notice that none of the devices you want to add, e.g., Lynxmotion AL5D robot manipulator, are in the list.
This is because the device needs to be connected before it can be added.
Here is what you would see if the iRobot Create 2 mobile robot was connected.
For now, just add your webcam and remember to return to this step when you want to use any USB device later in the course, e.g., an external webcam, the Lynxmotion AL5D robot manipulator, or the iRobot Create 2 mobile robot.
The device for the Lynxmotion AL5D robot manipulator is FTDI FT232R USB UART [0600]
.
The device for the iRobot Create 2 mobile robot is FTDI FT231X USB UART [1000]
.
Note: if your host operating system is Ubuntu, you should also enter the following in a terminal of your host machine and then restart the cram-vm
virtual machine:
$ sudo adduser $USER vboxsf
Step 5: Enable Host OS to Guest OS Copy and Paste
When doing exercises and assignments, you may wish to copy text from the host OS (Windows 11, probably) and paste it to the guest OS (Ubuntu 18.04). Note that pasting to the terminal is <shift> <ctrl> v
not <ctrl> v
.
To do this, we need to enable Shared Clipboard and Drag’n’Drop functionality between Guest and Host Machine.
To enable Host OS to Guest OS Copy and Paste, Guest Additions must be installed in the virtual machine. This has already been done in the cram-vm
virtual machine.
Power off your Ubuntu guest OS.
Choose the cram-vm
virtual machine and click on Settings.
Click on General and Advanced and select Shared Clipboard and choose the Bidirectional option.
Select Shared Drag 'n' Drop and choose the Bidirectional option.
When you restart the virtual machine, double check that the copy and paste, and the drag and drop functionalities are enabled.
Click on Devices and Shared Clipboard and choose the Bidirectional option.
Now, click on Devices and Drag and Drop and choose the Bidirectional option.
Everything is set up and the virtual machine can now be started. When Ubuntu 18.04 boots, enter the password cram
, if asked.
Accessing Physical Devices
For completeness, here are the instructions to access the Lynxmotion AL5D robot manipulator. Instructions for a USB camera will be added later. You can carry out these instructions when you have access to the robots and cameras in the lab.
If you are using the cram-vm
VM, don't forget to enable access to the USB ports; see Step 4 of VirtualBox Setup in Option A above.
Setup the Connection to the Lynxmotion AL5D Robot Manipulator
1. Switch on the robot.
2. Connect your laptop to the robot controller using the USB cable.
3. If you are using the cram-vm
VM, add the robot controller USB device to the list of registered USB devices by following the instructions in Step 5: Enable USB Devices of VirtualBox Setup in Option A above.
4. Check that everything is working, as follows.
- Open a new terminal and run the following command. Joint 0, i.e. the joint at the base of the robot, should rotate to the centre position.
echo "#0P1610S250" > "/dev/ttyUSB0" % setpoint 1610 for joint 0 at speed 250
5.Trouble shooting: if the robot does not move, do the following (recall that the superuser password is cram).
sudo usermod -a -G dialout cram
- Power down the virtual machine (or PC if you are running Ubuntu natively) and power it back up again for the permissions to take effect.
- Check that the device is connected by inspecting the message produced by the following command or by clicking on the small blue USB connector icon at the bottom of the Ubuntu window.
dmesg | grep -i FTDI
- If are using the
cram-vm
virtual machine and your host operating system is Ubuntu, you should also enter the following in a terminal of your host machine and then restart the virtual machine:
$ sudo adduser $USER vboxsf
- Repeat Step 4.
- If the virtual machine displays blank black screen, try pressing CTRL + F on your keyboard. It should then display the content.