This is research code (Android app) that enables a Loomo-to-Ubuntu-PC hard-wire connection with message passing in ROS. The intended architecture is to send Loomo sensor data to an on-board computer (Jetson) for heavy processing/planning, then send speed commands from the Jetson to the Loomo, all through ROS, with the ROS master running on the Jetson.
If you want to use our Android app as is, run abd install android_loomo_ros.apk
(see v1.0
release) from a PC to install the app on the Loomo. You still have to do steps 5 & 6 of "Starting from scratch", but then you can then skip down to the "After Installing Android App onto Loomo" part of this readme.
-
On an Ubuntu 16.04 PC, install ROS Kinetic and Android Studio.
-
Install
android_core
package on your Ubuntu 16.04 PC (can clone somewhere other than~/android_core
if desired):
sudo apt-get install ros-kinetic-rosjava-build-tools ros-kinetic-genjava
mkdir -p ~/android_core
wstool init -j4 ~/android_core/src https://raw.github.com/rosjava/rosjava/kinetic/android_core.rosinstall
cd ~/android_core
catkin_make
- Create a catkin workspace for this repo
mkdir -p ~/segway_ws/src
git clone https://github.com/mfe7/android_loomo_ros_core.git ~/segway_ws/src
cd ~/segway_ws
catkin_make
-
You are now done w/
catkin_make
(everything else is Android-related). Open up Andorid Studio and open theandroid_loomo_ros
project. -
Connect a USB-C cable between Loomo's head and the Ubuntu PC.
-
Choose
android_loomo_ros
as the build target, and click the green triangle (looks like play button) to build and install the android code onto Loomo.- Make sure the
params.yaml
file located in theandroid_loomo_ros
package is also on the Loomo at/sdcard/params.yaml
. This can be done by running:adb push params.yaml /sdcard/
- Make sure the
-
If that worked, there should be an app on the Loomo's home screen called
Loomo ROS
.
This section was based on this in case I left out important details.
- When running
catkin_make
in~/android_core
:- Make sure the line
export ANDROID_HOME=/opt/android-sdk
is in your~/.bashrc
- If not, run
echo “export ANDROID_HOME=/opt/android-sdk” >> ~/.bashrc
- Might have to change
/opt/android-sdk
depending on where you downloaded the SDK to
- If not, run
- Error: "Failed to install the following Android SDK packages as some licences have not been accepted"
- Solution:
yes | $ANDROID_HOME/tools/bin/sdkmanager "build-tools;28.0.3"
- Solution:
- Error: "Task :cv_bridge:verifyReleaseResources FAILED"
- Solution: change
package="cv_bridge"
topackage="com.github.rosjava.android_extras.cv_bridge"
in~/android_core/src/android_extras/cv_bridge/src/main/AndroidManifest.xml
- Solution: change
- Make sure the line
- When running
catkin_make
in~/segway_ws
- In all of your
build.gradle
files, make sure the compileSdkVersion is compatible with the API version- You can check Android Studio and API version in File > Settings > Appearance & Behavior > System Settings > Updates
- Make sure your Gradle and Gradle Plugin versions are compatible
- You can check Gradle and Gradle Plugin versions in File > Project Structure > Project
- Error: "Gradle SDL method not found: 'google()'
- Solution: change Gradle version to 4.4 (can be changed in File > Project Structure > Project or in
gradle-wrapper.properties
)
- Solution: change Gradle version to 4.4 (can be changed in File > Project Structure > Project or in
- In all of your
The important steps for connecting to the Loomo are (steps 0-2 are one-time only, steps 1-4 described more here: https://gist.github.com/mfe7/c8b21b38a1574f6c319095415ae9a9e8)
-
Set up an NTP server on your Ubuntu PC in order to sync the Ubuntu PC clock to the Loomo Android clock (very important!!). Sync to an NTP server from the internet, then provide a local NTP server for anyone in the 192.168.42.xxx network (Loomo-to-PC network created when USB is connected in next steps). I can share a
ntp.conf
file if needed.- If you edit
/etc/ntp.conf
, runsudo service ntp restart
to see changes.
- If you edit
-
Switch Loomo into Developer Mode (Settings > System > Loomo Developer > Developer Mode)
- (I think this requires an internet connection, so join a wifi network now.)
-
You might need to switch Android into Developer Mode (tap some setting 7 times...look online for instructions).
Note: For the current version of the ROS node, it's very important that the Loomo not be connected to wifi, because it'll try to use that interface (wlan0) for ROS msgs.
-
Connect USB cable from Loomo's USB-C port to PC's USB-A port.
-
On Loomo, turn on USB Tethering (Settings > Wireless & Networks > More... > Tethering & portable hotspot > USB tethering) On Ubuntu, you should see a popup from NetworkManager saying there's a new Wired Connection.
- If you want to configure a static IP for your PC in the network or want the Loomo to connect to the same "Wired Connection" every time, on Ubuntu PC, search "Network Connections" (Also can be found by clicking Wifi/Network symbol in top right corner > "Edit Connections...")> Add > Ethernet
- Connection name: Loomo (or whatever you want it to be)
- Go to "IPv4 Settings" tab
- Choose "Manual" in the drop down menu
- Under "Addresses", Add
- Address: 192.168.42.134 (example)
- Netmask: 24 (you can leave Gateway blank)
- Routes... > check "use this connection only for resources on its network" (this allows you to preserve internet connection when the Loomo connects via ethernet)
- After creating a static IP, add these two lines to your
~/.bashrc
(assuming your PC is the ROS master)export ROS_MASTER_URI=http://localhost:11311/
(ROS_MASTER_URI
should refer to the ROS master device, which in this case, is this PC)export ROS_IP=192.168.42.134
(Should always refer to the deviceROS_IP
is being set on)
- Run
source ~/.bashrc
to see changes. You can check that you have the rightROS_MASTER_URI
, etc. withecho $ROS_MASTER_URI
- If you want to configure a static IP for your PC in the network or want the Loomo to connect to the same "Wired Connection" every time, on Ubuntu PC, search "Network Connections" (Also can be found by clicking Wifi/Network symbol in top right corner > "Edit Connections...")> Add > Ethernet
At this point, the two devices are on a common network, and you should be able to ping one another.
-
Start ROS master on Ubuntu PC (i.e.
$ roscore
) (make sureROS_MASTER_URI
andROS IP
are properly configured.) -
Start the Loomo ROS app on the Loomo's touch screen interface
- If you get the error "insufficient permissions for device with ADB" (and when run command
adb devices
, next to device says "no permissions"), runadb kill-server ; sudo adb start-server
It should automatically start with the TF Publisher switch enabled, and after 5 seconds, the 2 Realsense/camera switches should go green automatically
- If you get the error "insufficient permissions for device with ADB" (and when run command
-
On Ubuntu PC, try
$ rostopic echo /LO01/realsense/depth
If that works, /tf should also have a lot of Loomo transforms and some of the other realsense camera topics should work. -
Try to send Twist msgs (linear speed, angular rate) to the Loomo on
/LO01/cmd_vel
, e.g. by using RQT or rostopic pub command line tool. The robot base should spin/drive forward/backward if you send these commands at a reasonable frequency (e.g. 10Hz).
If all of that worked, you're able to send/receive data from your Loomo using ROS! And there is little latency by using the USB connection, as compared to communicating through WiFi.
Networking the Loomo, a Jetson, and an external PC is very cumbersome via USB tethering; you have to tether to obtain an IP address in order to start a ROS master and then bridge the network for an external PC to observe the ROS activity. However, this can be streamlined by using a portable USB-powered router with gigabit ethernet ports. This will effectively replace steps 4 & 5 of "After Installing Android App onto Loomo".
- Jetson (always) connected to router via ethernet cable.
- Loomo (always) connected to router via ethernet cable. Use an OTG dongle + USB-A to USB-C dongle to connect ethernet cable to USB-C port of Loomo.
- Have to make sure OTG dongle is compatible with Android, or else it won't work.
- If you want an external PC to monitor ROS activity, connect to router via WiFi.
All three devices should now be networked together and they should be able to ping one another. The router can also be configured to assign each device a static IP based on its MAC address, so the ROS_IP
of each device never has to be changed. This is also handy if the Network Manager of the Jetson has to be disabled for whatever reason because USB tethering previously depended on the Network Manager to set a static IP.
- GL-AR750s Slate Router:
- LAN IP: 192.168.42.1 (type in LAN IP in a browser of a device connected to the router to configure router)
- User: root
- Pass: loomonet
- WIFI SSID: GL-AR750S-ado*
- Pass: loomonet
- LAN IP: 192.168.42.1 (type in LAN IP in a browser of a device connected to the router to configure router)
- To quit an application, tab the side of the head of the Loomo.
- If Ubuntu PC does not detect Loomo when plugged in via USB, make sure ADB server has started (i.e. run
sudo adb start-server
) - Get IP address of Loomo:
adb shell netcfg