Skip to content

Latest commit

 

History

History
297 lines (213 loc) · 14.7 KB

README.md

File metadata and controls

297 lines (213 loc) · 14.7 KB

RoPi Remote Controlled Robot

Table of Contents

RoPi is a software solution for controlling a Raspberry Pi based robot:

  • Python based backend and webserver
  • Web interface for remote controlling it from any browser
  • Support for using the Raspberry Pi Camera module

The reason behind implementing RoPi was offering the end user an easy to use solution for controlling the Raspberry Pi robot. It was implemented with the Pi2Go robot in mind but can be easily extended to support any other Raspberry Pi based robot.

How To Use It

Prerequisites

  • A Raspberry Pi based Robot
    • Pi2Go - Supported
    • GoPiGo - In progress
  • WiFi connection
  • Remote Access to the Raspberry Pi (eg. TightVNC) for installing RoPi
  • A device running a web-browser for remote controlling the robot
    • Known issue: the RoPi remote interface pulls a MJPEG stream from the camera (does not work in Internet Explorer)

Introduction

After installing the RoPi software on the robot and rebooting the Raspberry Pi the robot should be ready to play (on the Pi2Go the ready state is signaled by the side-LEDs turning on green). Typing the robot's address in a web browser will start the RoPi dashboard:

alt text

NOTE: By default the web interface is available on port 80.

Clicking the toggle button labeled "Off" will turn on the robot:

  • it is ready to receive commands
  • it starts pushing informations to the dashboard (distance to obstacles, temperature, CPU load, etc.)
  • if there is a Camera configured it starts streaming ("Cam On" toggle will be automatically activated)

It is possible for more than one person to watch the camera stream. In this scenario the one who controls the robot will start both the robot (green toggle shows "On") and the camera (blue toggle shows "Cam On"; the others will switch only the camera on (blue toggle "Cam On").

A demo video will be uploaded soon...

Screen Layout

The screen is split in 3 main areas:

  • the left gauge: it is a speedometer displaying the current speed (in percent), indicating the "cruising control" speed with a red triangle and showing a dummy (for now) odometer
  • the right gauge: it combines a temperature indicator with a "parking sensor"-like indicator below
  • between both gauges there is either an analog clock (when the camera is off) or the video stream of the PI's camera displayed

On the bottom right corner there are two buttons ( - and + ) used to decrease/increase the "cruising speed" of the robot.

Indicators

All available indicators are visible in the screenshot below:

alt text

Indicator Description
alt text Indicates a broken socket.io link with the server
alt text Indicates that the Front-assist feature is activated (less than 10cm to detected obstacle). The robot can be moved only to the left, right or backwards
alt text Indicates that the car is moving forward and the front-lights are on
alt text Indicates that the car is stopped (handbrake)
alt text Indicates that the ultrasonic sensor is activated (front parking sensors)
alt text Dummy seat belt indicator
alt text Indicates that the Raspberry Pi's temperature is too high (overheating)
alt text Indicates that the cruise control is activated and a certain speed is set
alt text Indicates that the robot is moving either to the left or to the right

The Parking Control indicator informs about the distance to the next obstacle (in cm) and indicates visually the proximity to that object. It also displays information about the 2 sensors used for following a line.

Above the parking control there is a temperature indicator for the current Raspberry Pi temperature.

The Odometer displayed inside the speed gauge is not working for now. It is planned to display there the distance traveled by the robot :)

Above the camera there is a working digital clock and a dummy outside temperature display. Under the camera there are two progress bars indicating the current CPU and memory load.

Controlling the Robot and the Camera

The screen is split into two logical areas. The left area is for controlling the robot's movement and the right area is for controlling the pan & tilt of the camera (if installed and activated).

By tapping on the left area (or on mouse down) a green virtual joystick will appear (see image above) and the robot will start moving accordingly to the joystick movements. By removing the finger from the screen (or mouse up) the robot will stop moving.

By tapping on the right area (or on mouse down) a blue virtual joystick will appear and the camera will pan and tilt accordingly to the joystick movements. By removing the finger from the screen (or mouse up) the camera will center (if the "Follow me" mode is currently selected).

Settings Menu

alt text

The Robot IP or Host entry is automatically populated with the address of the robot where the web interface is currently connected. This address is used for pushing robot data to the remote (socket.io) and for the camera stream. By modifying this address is possible to connect to the camera stream of a different robot (if needed).

  • The Shutdown Robot button will trigger a graceful shutdown of the Raspberry Pi's operating system. NOTE: You still need to manually switch off the robot itself.

  • The Reboot Robot button will trigger a restart of the Raspberry Pi's operating system.

  • The Stop Server button is usually used to stop the RoPi server running on the Raspberry (useful when debugging).

Installation

Finding the Robot in Your Network

If the robot has a user-customizable push button (like the Pi2Go for example) this could be used to ask the robot to send its IP address via email. This is useful when the robot is configured to use a dynamically assigned IP address.

Currently the button is configured to search for a file called "email_config.txt" in the ropi folder. The file must contain 3 rows each separated by a CRLF:

  • first row contains the Gmail address from which to send the IP
  • second row contains the password for the above email
  • third row contains the destination email address

Example email_config.txt file:

myrobot@gmail.com
mypassword
destination@xyz.com

NOTE: The robot sends the email using the Gmail service therefore the sender email address must be a Google email one.

Setup the Server

Interactive installation

An interactive installation script will be available soon.

Manual installation
  • Install the RoPi files

Fetch the RoPi repository to a ropi folder on your Raspberry Pi:

$ cd /home/pi
$ git clone https://github.com/ThumbGen/ropi.git
$ cd ropi/server
$ sudo ./app.py
  • Configure RoPi to autostart during boot

1 Create a ropi file for the startup script:

$ sudo nano /etc/init.d/ropi

2 Write the content below in that file:

#!/bin/sh

cd /home/pi/ropi/server
sudo ./app.py

esac

exit 0

3 Save and exit: Ctrl+X, Y, Enter

4 Make the script executable:

$ sudo chmod 755 /etc/init.d/ropi

5 Register script to be run at startup:

$ sudo update-rc.d ropi defaults

Setup the Camera

Under construction...

Technical Details

Conceptual diagram..coming soon.

The RoPi "architecture" is very simple and straightforward:

  • the robot layer contains the robot specific Python code and it is responsible for interfacing the robot's hardware with the next layer
  • the server layer contains logical modules implementing robot's "features" and a Python (Flask) web server offering a simple API for remote control
  • the remote control layer is a web-based interface designed around a car dashboard-concept; implementing it as a web application offers a great degree of portability: almost all browsers are supported and there is no "deployment" needed for the client

Robot API and Multiple Robot Types

In order to be able to use the server with various robots there is a very simple infrastructure prepared. Firstly during the startup of the server a configuration loader searches for a file named robotConfig.json in the folder where all other Python files reside. For now the file contains the minimum required information in order to properly choose the right robot.

Example for the Pi2Go robot:

{
  "title":"RoPiRemote",
  "robotType":"Pi2Go",
  "robotFile":"Pi2GoRobot.py"
}

Example for the GoPiGo robot:

{
  "title":"GoPiGo Remote",
  "robotType":"GoPiGo",
  "robotFile":"GoPiGoRobot.py"
}
  • title - will be displayed in the web interface as a badge
  • robotType - indicates the type of the robot currently configured
  • robotFile - indicates the file where the robot interface is implemented; this file will be loaded during startup and used for the communication with the robot's hardware

A script allowing to switch between various robot types will be provided soon. It will help during debugging/programming for different types of robots.

The interface the files Pi2GoRobot.py and GoPiGo.py file MUST implement is listed below:

  • init() - called once during the server's startup (used for initialising GPIO pins, switching motors and LEDs off, etc)
  • cleanup() - called once during the server's shutdown (used to set all motors and LEDs off and set GPIO to standard values)
  • setLED(led, red, green, blue) - set the LED specified to required RGB value (0 >= LED <= 4; 0 <= R,G,B <= 4095)
  • setAllLEDs(red, green, blue) - set all LEDs to required RGB (0 <= R,G,B <= 4095)
  • irLeft() - return the state of the left IR obstacle sensor
  • irRight() - return the state of the right IR obstacle sensor
  • irCentre() - return the state of the middle IR obstacle sensor
  • irLeftLine() - return state of the left IR line sensor
  • irRightLine() - return state of the right IR line sensor
  • getSwitch() - return the value of the switch (pressed == true)
  • getLight(index) - returns the value 0..1023 for the selected light sensor (0 <= index <= 3)
  • forward(speed) - set all motors to move forward at speed (0 <= speed <= 100)
  • reverse(speed) - set all motors to reverse at speed (0 <= speed <= 100)
  • spinLeft(speed) - sets motors to turn opposite directions at speed (0 <= speed <= 100)
  • spinRight(speed) - sets motors to turn opposite directions at speed (0 <= speed <= 100)
  • stop() - stop motors
  • turnForward(leftSpeed, rightSpeed) - move forwards in an arc by setting different speeds(0 <= leftSpeed,rightSpeed <= 100)
  • turnreverse(leftSpeed, rightSpeed) - move backwards in an arc by setting different speeds(0 <= leftSpeed,rightSpeed <= 100)
  • getDistance() - return the distance (in cm) to the nearest reflecting object (0 == no object)

Server

The server runs a very simple Python implementation. There are files containing isolated logic for various features of the robot. By using Flask a simplistic API was published for being used remotely.

Server API

The RoPi server can be used with a different web interface (or even native mobile apps) by accessing its API.

Click here for the server API documentation

Remote Control Web Interface

Coming soon...

Pending ToDos

  • make it work with the GoPiGo robot

References

RoPi uses a number of open source projects to work properly:

  • Twitter Bootstrap - great UI boilerplate for modern web apps
  • jQuery - fast, small, and feature-rich JavaScript library
  • js-cookie - a simple, lightweight JavaScript API for handling cookies
  • fabric.js - powerful and simple Javascript HTML5 canvas library
  • bootstrap-toggle - highly flexible Bootstrap plugin that converts checkboxes into toggles
  • nippleJS - a virtual joystick for touch capable interfaces
  • socket.io - enables real-time bidirectional event-based communication
  • SteelSeries-Canvas - the HTML5 Canvas port of the SteelSeries component library (gauges)