This Instructable will guide you through the building of Alice, the path following vehicle.
It consists of an Android application and an inexpensive miniature vehicle, that you can build using common parts found online or at your local electronics shop.
Alice, was built during the DIT524 course in the University of Gothenburg by the first year students Kai Salmon, Martina Freiholtz, Tobias Lindell, Rachele Mello and Linhang Nie. I was supervising them and provided them with the hardware platform and two Arduino libraries (, ), which enabled them to easily work with it.
They built a system, that allows the user to draw a path directly on the phone's screen and then the vehicle to follow it. Their product, is a proof of concept, which could be utilized to dynamically draw a path over a predetermined area, in a user friendly way, for a robot or a vehicle to follow the sketched route and possibly execute some tasks. Some real life cases where this could be used, include a factory floor or a warehouse, where a robot should move to a specific location, pick something and move it to another spot. Alternatively, another use case could involve the system in an emergency situation, where a robot would be tasked to visit specific locations and deliver supplies or provide assistance.
Before moving on to the specifics, check this demo video out.
Step 1: Building the Car - Hardware
In order to build, or rather assemble, the car you will need the following components:
- Car chassis (you can find the ones displayed here, on Ebay or AliExpress, by searching for "smart robot car")
- Two (or four) DC motors
- Wheels (for easiness, buy a kit that contains all the above)
- Arduino Mega
- L293D motor shield (used to be made by Adafruit, but now you can find them sold by Chinese resellers)
- L3G4200D Gyroscope (used in order to rotate the car at specific degrees)
- Speed encoders (this or this will suit the car kit I suggested above)
- HC-SR04 ultrasonic sensor (used in order to detect obstacles in the front of the vehicle)
- HC-06 Bluetooth module (used to communicate with the Android phone)
- Battery pack (we use a 12 Volt one, with 8 AA batteries)
Of course you do not have to use these specific components. I am just mentioning the ones found on "Alice" and with which, the software referenced here should work mostly out of the box. The cost of "Alice" is approximately 40$ if everything is bought from China.
Refer to the schema in order to understand how the various connections are made.
In brief, the motors get attached to the motor shield as does the battery pack. The gyroscope gets connected to the I2C bus and don't forget to connect the SD0 pin to the 5V. Connect the wheel encoder to pin 19 (or any other pin that supports external interrupt) and the Bluetooth module to a Serial port (RX to TX and TX to RX). Finally, connect the ultrasonic sensor to any two input pins.
Step 2: Building the Car - Software - Arduino
The Arduino Mega, found on the path following vehicle, runs the Arduino sketch found here. After the user draws a path, it receives all the necessary commands and stores them in a custom made buffer, where each command is executed sequentially.
If an obstacle is found, then the vehicle stops and sends back to the Android phone, the index of the command that was being executed, while the obstacle was met. Therefore, the application can determine and visualize, where on the path the obstacle was encountered.
In order to run this sketch, you have to download and install two Arduino libraries. The Smartcar Core and the Smartcar Sensors. If you do not know how to do this, check this out.
Also, take a look in the Wikis of the two libraries. You will find extensive information regarding their usage and especially how to apply them in different settings, i.e. if you are not using exactly the same components as we did.
Ultimately, you should be able to make the car rotate clockwise by 90 degrees, by typing alice.rotateClockwise(90) or instruct it to travel 100 centimeters to the front with alice.goForward(100).
Step 3: Building the Car - Software - Android
The Android application used to draw the path and send the instructions to the vehicle, via Bluetooth, can be found here.
You can download the already built APK that I have attached below. However since you generally should NOT install APK's from unknown sources over the internet, I strongly advise you to download the source, review it, then build it yourselves and install it.
You can do that by cloning the repository, or just downloading it as a .zip file. Then, import it in Android Studio or whatever IDE you are using. The application has just one dependency, the appcompat library, which you might have if you are already working with Android. Don't worry about this anyway, if you are missing it, you can easily install it through the IDE after being notified of its absence.
The Android application is composed of three screens.
- The path drawer, which is the application's backbone, where the user is able to draw the path on the screen, connect to the vehicle, send the instructions, drive it manually or access the settings menu. You will get notified if the vehicle has met an obstacle, so you can either change the course, order it to continue if the "threat" is not valid or even drive it manually to avoid the obstruction.
- The settings menu, where the user can define various parameters such as the sensitivity of how the path is drawn or the size of the actual area where the robot should drive. Moreover, you can choose to add a picture to draw the path over. In this case, this picture could be the blueprints of a floor, or a map of an area in which you want to navigate your vehicle.
- The manual control window, where the user can steer the car manually, using a joystick.
Step 4: That's About It!
It wasn't so hard, was it? Now all you have to do is try it out and why not, try to improve things! I believe this concept has the potential to be used in a non hobbyist environment, in order to improve or even save lives.
I did not provide extensive details on how to build the vehicle, since you should not feel confined in using the exact one we did. If you have any questions regarding the assembly or programming, do not hesitate to leave a comment below.