e-puck2: Difference between revisions
| Line 292: | Line 292: | ||
| =Radio module= | =Radio module= | ||
| The radio module chosen for the e-puck is the new ESP32 chip from [https://www.espressif.com/ Espressif], integrating a dual core that run up to 240 MHz, 4 MB of flash and 520 KB of RAM. It supports WiFi standards 802.11 b/g/n (access point mode supported), Bluetooth and Bluetooth LE 4.2.   | The radio module chosen for the e-puck is the new ESP32 chip from [https://www.espressif.com/ Espressif], integrating a dual core that run up to 240 MHz, 4 MB of flash and 520 KB of RAM. It supports WiFi standards 802.11 b/g/n (access point mode supported), Bluetooth and Bluetooth LE 4.2. It is the successor of the ESP8266 chip. The following figure shows the various peripherals available on the ESP32:<br/> | ||
| [http://www.gctronic.com/doc/index.php?title=e-puck2_radio_module_development Radio module development] | [http://www.gctronic.com/doc/index.php?title=e-puck2_radio_module_development Radio module development] | ||
| =Programmer= | =Programmer= | ||
| [http://www.gctronic.com/doc/index.php?title=e-puck2_programmer_development Programmer development] | [http://www.gctronic.com/doc/index.php?title=e-puck2_programmer_development Programmer development] | ||
Revision as of 12:25, 27 July 2018
1 Hardware
1.1 Overview
The following figures show the main components offered by the e-puck2 robot and where they are physically placed:

1.2 Specifications
The e-puck2 robot maintains full compatibility with its predecessor e-puck (e-puck HWRev 1.3 is considered in the following table):
| Feature | e-puck1.3 | e-puck2 | Compatibility | Additional | 
| Size, weight | 70 mm diameter, 55 mm height, 150 g | Same form factor: 70 mm diameter, 45 mm, 130 g |   | No e-jumper required | 
| Battery, autonomy | LiIPo rechargeable battery (external charger), 1800 mAh. About 3 hours autonomy. Recharging time about 2-3h. | Same battery; USB charging, recharging time about 2.5h. |   | USB charging | 
| Processor | 16-bit dsPIC30F6014A @ 60MHz (15 MIPS), DSP core for signal processing | 32-bit STM32F407 @ 168 MHz (210 DMIPS), DSP and FPU, DMA |   | ~10 times faster | 
| Memory | RAM: 8 KB; Flash: 144 KB | RAM: 192 KB; Flash: 1024 KB |   | RAM: 24x more capable Flash:~7x more capable | 
| Motors | 2 stepper motors with a 50:1 reduction gear; 20 steps per revolution; about 0.13 mm resolution | Same motors |   | |
| Wheels | Wheels diamater = 41 mm Distance between wheels = 53 mm | Same wheels |   | |
| Speed | Max: 1000 steps/s (about 12.9 cm/s) | Max: 1200 steps/s (about 15.4 cm/s) |   | 20% faster | 
| Mechanical structure | Transparent plastic body supporting PCBs, battery and motors | Same mechanics |   | |
| Distance sensor | 8 infra-red sensors measuring ambient light and proximity of objects up to 6 cm | Same infra-red sensors Front real distance sensor, Time of fight (ToF), up to 2 meter. |   | ToF sensor | 
| IMU | 3D accelerometer and 3D gyro | 3D accelerometer, 3D gyro, 3D magnetometer |   | 3D magnetometer | 
| Camera | VGA color camera; typical use: 52x39 or 480x1 | Same camera; typical use: 160x120 |   | Bigger images handling | 
| Audio | 3 omni-directional microphones for sound localization speaker capable of playing WAV or tone sounds | 4 omni-directional microhpones (digital) for sound localization speaker capable of playing WAV or tone sounds |   | +1 front microphone | 
| LEDs | 8 red LEDs around the robot, green body light, 1 strong red LED in front | 4 red LEDs and 4 RGB LEDs around the robot, green light, 1 strong red LED in front |   | 4x RGB LEDs | 
| Communication | RS232 and Bluetooth 2.0 for connection and programming | USB Full-speed, Bluetooth 2.0, BLE, WiFi |   | WiFi, BLE | 
| Storage | Not available | Micro SD slot |   | Micro SD | 
| Remote Control | Infra-red receiver for standard remote control commands | Same receiver |   | |
| Switch / selector | 16 position rotating switch | Same selector |   | |
| Extensions | Ground sensors, range and bearing, RGB panel, Gumstix extension, omnivision, your own | All extension supported |   | |
| Programming | Free C compiler and IDE, Webots simulator, external debugger | Free C compiler and IDE, Webots simulator, onboard debugger (GDB) |   | Onboard debugger | 
This is the overall communication schema:

1.3 Documentation
- Main microcontroller: STM32F407, datasheet, reference-manual
- Programmer/debugger: STM32F413, datasheet, reference-manual
- Radio module: Espressif ESP32, datasheet, reference-manual
- Camera: PixelPlus PO8030D CMOS image sensor, datasheet, no IR cut filter
- Microphones: STM-MP45DT02, datasheet
- Optical sensors: Vishay Semiconductors Reflective Optical Sensor, datasheet
- ToF distance sensor: STM-VL53L0X, datasheet, user-manual
- IMU: InvenSense MPU-9250, product-specification, register-map
- Motors: details
- Speaker: Diameter 13mm, power 500mW, 8 Ohm, DS-1389 or PSR12N08AK or similar
- IR receiver: TSOP36230
1.4 Migrating from e-puck1.x to e-puck2
The e-puck2 robot maintains full compatibility with its predecessor e-puck, but there are some improvements that you should be aware of.
First of all the e-jumper, that is the small board that is attached on top of the e-puck1.x, isn't anymore needed in the e-puck2. The components available on the e-jumper are integrated directly in the robot board. On top of the e-puck2 you'll see a quite big free connector, this is used to attach the extensions board designed for the e-puck1.x that are fully compatible with the e-puck2; you must not connect the e-jumper in this connector.
Secondly you don't need anymore to unplug and plugin the battery for charging, but instead you can charge the battery (up to 1 ampere) directly by connecting the USB cable. If you want you can still charge the battery with the e-puck1.x external charger, in case you have more than one battery.
Moreover you don't need anymore a special serial cable (with probably an RS232 to USB adapter) to be able to communicate with the robot, but you can use the USB cable. Once connected to the computer a serial port will be available that you can use to easily exchange data with the robot.
1.5 Extensions
All the extensions (ground sensors, range and bearing, RGB panel, gumstix and omnvision) are supported by the e-puck2 robot, this means that if you have some extensions for the e-puck1.x you can still use them also with e-puck2.
For more information about using the gumstix extension with e-puck2 robot refer to http://www.gctronic.com/doc/index.php?title=Overo_Extension#e-puck2.
2 Getting Started
The e-puck2 robot features 3 chips onboard:
- the main microcontroller, that is responsible for handling the sensors and actuators and which runs also the demos/algorithms
- the programmer, that provides programming/debugging capabilties and moreover it configures the USB hub and is responsible for the power management (on/off of the robot and battery measure)
- radio module, that is responsible for handling the wireless communication (WiFi, BLE, BT), the RGB LEDs and the user button (the RGB LEDs and button are connected to the radio module due to the pin number limitation on the main microcontroller)
The following sections explain the basic usage of the robot, more detailed information can be found following the links provided.
2.1 Turn on/off the robot
To turn on the robot you need to press the power button (blue button) placed on the bottom side of the board, near the speaker, as shown in the following figures:
To turn off the robot you need to press the power button for 1 second.
2.2 Meaning of the LEDs
The e-puck2 has three groups of LEDs that are not controllable by the user.
- Charger: RED if charging, GREEN if charge complete and RED and GREEN if an error occurs
- USB: Turned ON if the e-puck2 detects a USB connection with a computer
- STATUS: Turned ON if the robot is ON and OFF if the robot is OFF. When ON, gives an indication of the level of the battery. Also blinks GREEN if the program is running during a debug session.
Battery level indications (STATUS RGB LED):
- GREEN if the system's tension is greater than 3.5V
- ORANGE if the system's tension is between 3.5V and 3.4V
- RED if the system's tension is between 3.4V and 3.3V
- RED blinking if the system's tension is below 3.3V
The robot is automatically turned OFF if the system's tension gets below 3.2V during 10 seconds.
2.3 Connecting the USB cable
A micro USB cable (included with the robot in the package) is needed to connect the robot to the computer. There are two connectors, one placed on top of the robot facing upwards and the other placed on the side of the robot, as shown in the following figures. Both can be used to charge the robot (up to 1 ampere) or to communicate with it, but do not connect two cables at the same time. Connect the USB cable where is more comfortable to you.
2.4 Installing the USB drivers
The USB drivers must be installed only for the users of a Windows version older than Windows 10:
- Download and open zadig-2.3.exe
- Connect the e-puck2 with the USB cable and turn it on. Three unknown devices appear in the device list of the program, namely e-puck2 STM32F407, e-puck2 GDB Server (Interface 0) and e-puck2 Serial Monitor (Interface 2).
- For each of the three devices mentioned above, select the USB Serial (CDC)driver and click on theInstall Driverbutton to install it. Accept the different prompts which may appear during the process. At the end you can simply quit the program and the drivers are installed. These steps are illustrated on Figure 3 below.
- Note : The drivers installed are located in C:\Users\"your_user_name"\usb_driver
 
- Note : The drivers installed are located in 
The drivers are automatically installed with Windows 10, Linux and Mac OS.
Anyway in Linux in order to access the serial ports, a little configuration is needed. Type the following command in a terminal session: sudo adduser $USER dialout. Once done, you need to log off to let the change take effect.
2.5 Finding the USB serial ports used
Two ports are created by the e-puck2's programmer when the USB cable is connected to the robot (even if the robot is turned off):
- e-puck2 GDB Server. The port used to program and debug the e-puck2.
- e-puck2 Serial Monitor. Serial communication between the PC and the radio module (used also to program the radio module).
A third port could be available depending on the code inside the e-puck2's microcontroller. With the standard firmware a port named e-puck2 STM32F407 is created.
2.5.1 Windows
- Open the Device Manager
- Under Ports (COM & LPT) you can see the virtual ports connected to your computer.
- Do a Right-click -> properties on the COM port you want to identify.
- Go under the details tab and select Bus reported device description in the properties list.
- The name of the port should be written in the text box below.
- Once you found the desired device, you can simply look at its port number (COMX).
2.5.2 Linux
- 1. Open a terminal window (ctrl+alt+t) and enter the following command:ls /dev/ttyACM*
- 2. Look for ttyACM0 and ttyACM1 in the generated list, which are respectively e-puck2 GDB Server and e-puck2 Serial Monitor. ttyACM2 will be also available with the standard firmware, that is related to e-puck2 STM32F407 port
Note : Virtual serial port numbering on Linux depends on the connections order, thus it can be different if another device using virtual serial ports is already connected to your computer before connecting the robot.
2.5.3 Mac
- 1. Open a terminal window and enter the following command: ls /dev/cu.usbmodem*
- 2. Look for two cu.usbmodemXXXX, where XXXX is the number attributed by your computer. You should find two names, with a numbering near to each other, which are respectively e-puck2 GDB Server and e-puck2 Serial Monitor. A third device cu.usbmodemXXXX will be available with the standard firmware, that is related to e-puck2 STM32F407 port
Note : Virtual serial port numbering on Mac depends on the physical USB port used and the device. If you want to keep the same names, you must connect to the same USB port each time.
2.6 PC interface

A PC application was developed to start playing with the robot: you can have information about all the sensors, receive camera images and control the leds and motors.
With the standard firmware programmed in the robot, place the selector in position 8, attach the USB cable and turn on the robot. Enter the correct port (the one related to e-puck2 STM32F407) in the interface and click connect.
The source code is available from the repository https://github.com/e-puck2/monitor.
Available executables:
- Windows executable: tested on Windows 7 and Windows 10
- Max OS X executable
On Linux remember to apply the configuration explained in the chapter Installing the USB drivers in order to access the serial port.
2.7 PC side development
This section is dedicated to the users that develop algorithms on the PC side and interact with the robot remotely through a predefined communication protocol. These users don't modify the firmware of the robot, but instead they use the standard firmware released with the robot. They update the robot firmware only when there is an official update. 
The remote control of the robot, by receiving sensors values and setting the actuators, is done through the following channels: Bluetooth, Bluetooth Low Energy, WiFi, USB cable.
Examples of tools/environment used by these users:
- Aseba
- Simulator (e.g. Webots)
- ROS
- iOS, Android apps
- Custom PC application
- IoT (e.g. IFTTT)
If you fall into this category, then follow this section for more information: PC side development.
3 Main microcontroller
The e-puck2 robot main microcontroller is a 32-bit STM32F407 that runs at 168 MHz (210 DMIPS) and include DSP, FPU and DMA capabilities. The version chosen for the e-puck2 has 192 KB of total RAM and 1024 KB of flash, so there is a lot of memory to work with.
3.1 Standard firmware
The robot is initially programmed with a firmware that includes many demos that could be started based on the selector position, here is a list of the demos with related position and a small description:
- Selector position 0: Aseba
- Selector position 1: Shell
- Selector position 2: Read proximity sensors
- Selector position 3: Asercom protocol v2 (BT)
- Selector positoin 4: Range and bearing extension (receiver)
- Selector position 5: Range and bearing extension (transmitter)
- Selector position 6: ESP32 UART communication test
- Selector position 7: ...
- Selector position 8: Asercom protocol v2 (USB)
- Selector position 9: Asercom protocol (BT)
- Selector position 10: This position is used to work with the gumstix extension.
- Selector position 11: Simple obstacle avoidance + some animation
- Selector position 12: Hardware test
- Selector position 13: LEDs reflect orientation of the robot
- Selector position 14: Read magnetometer sensor
- Selector position 15: ...
The pre-built firmware is available here robot standard firmware.
3.2 Robot side development
If you are an embedded developer and are brave enough, then you have complete access to the source code running on the robot, so you can discover what happen inside the main microcontroller and modify it to accomodate your needs. Normally the users that fall into this category develop algorithms optimized to run directly on the microcontroller, such as:
- onboard image processing
- swarm algorithms
- fully autonomous behaviors
- ...
For more information about programming the robot itself, refer to section Robot side development
4 Radio module
The radio module chosen for the e-puck is the new ESP32 chip from Espressif, integrating a dual core that run up to 240 MHz, 4 MB of flash and 520 KB of RAM. It supports WiFi standards 802.11 b/g/n (access point mode supported), Bluetooth and Bluetooth LE 4.2. It is the successor of the ESP8266 chip. The following figure shows the various peripherals available on the ESP32:







