Table of Contents generated with DocToc
A robot to detect when Daphne (my year old husky mix) is on the counter that uses image recognition via Tensor Flow Lite.
-
Raspberry PI 4. Tensor Flow will fully tap one of the 4 cpu cores of the arm 71 on the PI 4
-
Adafruit Braincraft Hat. This little hat is packed with features we will make use.
-
Adafruit DC & Stepper Motor Hat. Any I2C DC motor driver will work. If you get a hat or bonnet style, get it without any headers if you can. The Adafruit one here is a kit that you need to (NOT) solder the PI headers on. The Braincraft hat above really doesn't allow for anything between it and the Raspberry PI because of the cpu fan, and you don't want to stack on top of it or no buttons, LEDs or display. That's okay though, we'll make the stepper motor hat into an infinitely more useful Stemma-QT I2C compatible device with just four solder points using a...
-
Stemma QT 4 pin plug. We'll use this to get I2C, 3.3V and Gnd to the motor controller hat.
-
A little speaker. <- this one comes with a JST connector that will plug right into the Braincraft hat
-
2 x Basic PIR sensor. We'll use these to tell when there is motion in the periphery of view and rotate daph-bot toward the action.
-
2 x UBEC DC to DC stepdown. We'll use two separate stepdown voltage regulators for the PI and the motors and will allow us to use a variety of single battery or power supply options.
-
A robot frame with 2 DC motors. I used one like this that I got from IDK where, but the base was bigger than I wanted so I 3D printed my own.
-
Some Risers to stack things up
-
Some spare wires in different colors
- Setup the PI for headless
- Install all of the things. Continue to the next pages from there to setup Blinka, Audio, Fan, Display Module, Camera,
- Setup Tensorflow Lite on the PI Follow on with the next pages from there to setup Tensor flow and test that it works. When finished you should be able to run the following commands from the pi home directory
cd /home/pi
sudo bash
cd rpi-vision && . .venv/bin/activate
python3 tests/pitft_labeled_output.py --tflite
And see the data (guesses) tensor flow is seeing. The code for daph-bot will use the output of the command above to detect when Daphne is present.
- Install some more software
On the raspberry PI:
sudo pip3 install adafruit-circuitpython-motorkit adafruit-circuitpython-dotstar
To get sound working and .mp3 files to play, I needed to install some additional debian packages:
sudo apt-get install libasound2-plugins
sudo apt-get install mpg123
- Init ssh key and create data and logs directories
Copying your SSH public key to the PI user's authorized_keys files will make updating your code on the pi easier.
See scripts/init.sh for example meant to be run from Mac terminal. If you edit HOSTNAME
to match your user@raspberry.local
, you should be able to use the script.
If you didn't use the script above, don't forget to create the logs directory. For example, on the PI in the pi user home directory,
mkdir -p logs
- Copy directories from this repository
From your computer, copy the following directories with files to the PI user's home directory. See, for example, scripts/upload.sh
Be sure to copy all of the following directories:
- data/
- lib/
- media/
- scripts/
When you log into your PI as pi@yourraspberry.local you should see these directories using the ls
command. It should look like:
pi@trainerbot:~ $ ls
data lib logs media Raspberry-Pi-Installer-Scripts raspi-blinka.py rpi-vision scripts seeed-voicecard
There are 4 semi independent python programs running that make daph-bot work. (The paths are from the /home/pi directory on the raspberry)
This was installed as part of setting up Tensor Flow Lite. See, Things You'll Need To Do, above.
It's output looks like,
INFO:root:TFLite inference took 100 ms, 9.9 FPS
INFO:root:[('n03207941', 'dishwasher', 0.17871304), ('n03761084', 'microwave', 0.16713606), ('n04590129', 'window_shade', 0.10856207), ('n04404412', 'television', 0.03231336), ('n03201208', 'dining_table', 0.024060488)]
It is controlling the camera and the LCD display, passing about 10fps of image to Tensor Flow and writing a stream of log information to stderr
. Instead of digging into how to create machine learning models or how that program works or is maintained, let's just treat it like a black box and pipe it's output to another program....
This should probably be called parse things. It parses the output from pitft_labeled_output.py
uniqueThings.py also keeps a log of unique things seen and their counts (logs/uniqueThings.txt) so you can generate your own data/daphneThings.txt. You can just point daph-bot's camera at your furry friend and then edit the logs/uniqueThings.txt file to remove any lines that are obviously not.
uniqueThings.py writes each thing it sees, whether it has seen it or not, to it's stdout
.
This python program takes the stream of things from uniqueThings.py one per line looks for any sightings of Daphne things (data/daphneThings.txt) in the stream of image recognition data.
When it gets a match on a Daphne thing, it creates file (data/ALERT.txt) to signal motor control and anyone (you) debugging that it has an sighting and logs the sighting to logs/daphneSightings.txt for debugging.
After a few seconds without any sightings, it removes data/ALERT.txt.
This program interfaces with the Raspberry GPIO to read the sensors, change LED colors and control the motors of daph-bot.
It continuously checks for
- when both PIR sensors on GPIO 12 (left) and GPIO 13 (right) are hot, then stop moving and let the pixie dust settle
- when the left PIR sensor is hot and right is cold, then rotate left to bring the action into view
- when the right PIR sensor is hot and left is cold, then rotate right to bring the action into view
- when the data/ALERT.txt file created by watcher.py exists, then do a little quick forward / backward motion and light the center LED red
The PIR sensors need to be mounted to your bot frame such that there is a little overlap in their field of view (FOV). The PIR sensor listed under Things You Need to Find above have a 120 degree field of view.
- SSH to the raspberry PI and edit the /etc/rc.local file
sudo nano /etc/rc.local
- Add the following to rc.local. Just before the
exit 0
add
# send stdout and stderr from rc.local to a log file so you
# can see the error message if startup fails
exec 1>/home/pi/logs/rc.local.log 2>&1
set -x
cd /home/pi && /home/pi/scripts/run.sh
- Save and close the file. When back at the shell prompt, chg the mode of the /etc/rc.local file to make it executable
sudo chmod +x /etc/rc.local
That's it! Try it out
sudo reboot now