Cone icon by Fornax, CC-BY-SA 3.0, wikimedia commons 1)

Published 6 Feb 2018

Arduino controller for Cybot


I have received a discarded Cybot robot which is mostly complete and decided to replace its control chips with an Arduino, which will require writing software to control the motors and receive inputs from the ultrasonic and LDR sensors. There are quite a few projects on the internet that reuse the Cybot hardware but replace or modify the sensors and interface boards - the objective with this project is to make a substitute for the processor board, that can plug into any other unmodified Cybot.

Cybot side view Cybot top view
A mostly complete RealRobots Cybot

Overview

Surprisingly the Cybot was in basic working order, although the front caster wheel was missing. Fortunately the batteries had not leaked, and after replacing them it fired up ok. But as an autonomous robot it does not perform brilliantly, and could do with a bit more sophistication.

Hardware description

The Cybot was originally built in stages from kitset parts supplied with a magazine. It is built on a three-wheeled platform, with two independent driving wheels and one caster wheel to balance the front. There is a 6-volt battery holder for the wheels and a separate 9V battery to drive the electronics. Interface and controller boards are modular and plug together as more features are added. There were a number of stages, developing eventually to a remote-controlled beast. But the one I have was just at the end of the first stage, it has two powered wheels with an H-bridge control circuit made of discrete components, two Light Dependent Resistors (LDRs) for detecting light sources, a line following module, and two pairs of ultrasonic transmitter/receivers for detecting its environment.

Using the ultrasonic sensors appears to be the most difficult part. They have a fairly minimal interface, but from 3rd party documentation should produce 40kHz pulses when something reflects the signal, perhaps an interrupt-driven routine will be useful. There are a few other projects on the Internet that have made these types of modifications, but all seem to have skipped the ultrasonic sensors, some even add other more sophisticated ultrasonic range finding hardware instead.

There appears to be a requirement for 15 I/O pins from the controller.

The Light I/O board:

DirectionLabelDescription
IL_Fline follower input
Obuzzer 1buzzer driver output
Obuzzer 2 - drive one high and one low at the same time, gives 10V across transducer
I/OLDR leftlight dependent resistor input/discharge
I/OLDR rightlight dependent resistor input/discharge
OLEDantenna LEDs on/off
Omotor 2amotor forward/reverse drivers, PWM lines?
Omotor 2b - can not let both go low together as forms a short circuit
Omotor 1amotor forward/reverse drivers, PWM lines?
Omotor 1b - can not let both go low together as forms a short circuit


Sonar I/O board:

DirectionLabelDescription
OPZ-01outputs to drive ultrasonic transmitters
OPZ-02 - drive one high and one low at the same time, gives 10V across transducer
Ogate1select left/right receivers
Ogate2
Ioutputreceived echo signal

Replacing the Cybot functions

Arduino Sonar replacement

The most difficult controller function to replace appears to me to be the ultrasonic sensors. The hardware is fairly minimal and a lot of the work has to be done in software.

The Arduino has to generate the 40kHz, 10V p-p, driving signal for the two transmitters, then check for a received echo on the right and left receivers. The echo signal should provide range information as well as just presence/absence of obstructions. The sensors face forward on an angle so do not actually tell you whether the detected object is forward or to the sides of the Cybot. If an object is directly ahead, and flat, both sensors should receive an equal signal that decreases in distance as the Cybot advances, but two converging walls on either side would produce a similar result.

I decided that the software echo detector should be interrupt-driven, so that the Cybot can continue to manoeuvre etc, and have the sensors update independently. The output of the Cybot sonar board is a negative-going pulse for each echo received. Looking at an oscilloscope I see many more echo pulses than wave cycles transmitted, I expect that the Cybot's pings are bouncing back and forth between the Cybot and the target, generating multiple echoes. The transmitter produces a broad pulse, so there are also multiple echoes from different directions and distances so there are groups of echoes returned. Difficult to interpret all the echoes, so we will ignore all but the first pulse seen after sending our ping - that will give us the distance to the nearest object.

ASCII ASCII

On the left is one of the sonar driver outputs (top trace) with the multiple echoes (bottom trace). On the right, on a longer time base, is again the sonar pulse (top trace), and multiple groups of echo from different objects (bottom trace)

Arduino Sonar wiring

Tested by connecting the Arduino directly to the sonar board, supplying power to the Arduino and Sonar board via the USB connector.

ArduinoDirectionCybot BoardDescription
Pin Sonar I/O Pin
GND-13GNDground
+5V-11+5Vpower
6O6PZ-01outputs to drive ultrasonic transmitters
7O5PZ-02- drive one high and one low at the same time, gives 10V across transducer
2I4outputreceived echo signal, to generate an interrupt
4I/O3gate1select left/right receivers
5I/O2gate2- disable by pulling low, enable by letting float (switch to input mode)

Arduino Sonar test code

Arduino Sonar obstacle avoidance testing

Cybot with Arduino UNO
Cybot fitted with Arduino UNO controller and LCD display

Arduino to Cybot connections

Test drive of Cybot showing it sometimes avoiding hard surfaces, sometimes crashing into them. Also shows stall detection when it runs into an edge that the angled front sonar detectors can not see - after 20 seconds it decides it is stalled, and restarts. (NB in this test the front wheel is tending to veer right so the Cybot does not travel in straight lines).

Test drive of Arduino controlled Cybot

My main problem was detecting when the Cybot had got itself into trouble and was not moving. I tried looking at whether the sonar echos were unchanging - indicating it was not moving (or there was a very uniform environment), but there was too much “noise”, natural variability, in the returned echos to tell the difference. Of course there are lots of ways involving adding extra sensors (eg wheel rotation detectors) to detect whether it was stalled, but adding them would be going against the plan of trying to make the best Cybot using the current hardware, but just replacing the brains. I did add a voltage divider to monitor the battery level using an Arduino analog input - when stalled the Cybot draws a lot of current and because of the batteries internal resistance, the voltage drops. While not actually adding another active sensor device, this is cheating a little. Not 100% successful as on smooth surfaces the Cybot's wheels just spin when it is stalled, so the current peek is not as high.

For testing purposes the Arduino was fitted with an LCD display so that I could monitor what the code was seeing, and what it “thought” its current state was (eg running, turning, stalled). This version monitors current speed, battery voltage, and the left and right sonar return levels.

Cybot LCD status display

I had also tried feeding this information back to my desktop PC via the serial cable, including operating an onboard ring buffer log which could be played back when the Cybot was again connected to the computer's USB port. But all these approaches have their limitations, perhaps I need to go for a wireless real-time communication channel, eg infrared, Bluetooth, or WiFi, combined with a video record of what the Cybot was seen to be doing at the time.

References and Additional Resources

Cybot Sonar

Cybot builders


Rebuilding Cybot with alternative controllers

If any referenced page no longer exists, try looking for its URL on http://archive.org.


 Home Page   About this Site   Copyright Questions   Contact Us


1) PAGE UNDER CONSTRUCTION