GreenMachine is a kiosk that detects cafeteria objects and projects colored boxes onto them based on their waste type (compost, recycling, trash, and reusable). The goal is to make it easy for people to quickly know in which bins to throw their waste, avoiding confusion and guessing.
This project is open-source under an MIT license. See LICENSE.md.
- A Jetson TX2 flashed with Jetpack 3.2 (The TX2 developer kit comes pre-flashed)
- A CSI Camera (Included in the developer kit)
- A 720p or greater projector (Optional)
Turn on your Jetson and log in with the username nvidia
and password nvidia
.
Download this TensorFlow wheel and move it to your home directory.
In a terminal window, type this (without the $
) to download GreenMachine:
$ git clone https://github.com/NVIDIA-Jetson/GreenMachine
Then install GreenMachine and its dependencies:
$ cd ..
$ cd GreenMachine/src
$ python GreenMachine.py --install
Next, Follow this guide to install the Argus Camera library.
Finally, install tf_trt_models:
$ git clone --recursive https://github.com/NVIDIA-Jetson/tf_trt_models.git
$ cd tf_trt_models
$ ./install.sh
Then run (with a projector):
$ python Calibrate.py
$ python GreenMachine.py
Or without a projector:
$ python GreenMachine.py --screen
Hardware:
- A Jetson TX2
- A CSI Camera (Included in Jetson TX2 Developer Kit)
- A 720p Projector (Optional)
Software:
- A JetPack 3.2 (Pre-Flahsed in the Jetson TX2 Developer Kit)
- A Host Machine running Ubuntu 16.04 (Optional, only needed for training)
If you have a projector, you can see examples of projector/camera mounts on this wiki page. It is difficult to set up a mount and match the projector and camera's field of views, but once you do, projector mode can be used.
If you only have a monitor or do not want to mount the projector, you can still run GreenMachine in screen mode. All you need for this mode is a display.
If your Jetson is not already flashed (which it should be if you have the developer kit), follow this guide to flash it before you start installation.
Install Dependencies:
First, download this TensorFlow wheel.
Then use pip
to install dependencies (in the same directory that the TensorFlow wheel is in):
$ sudo pip install numpy
$ sudo pip install opencv-python
$ sudo pip install matplotlib
$ sudo pip install pillow
$ sudo pip install tensorflow-1.8.0-cp27-cp27mu-linux_aarch64.whl
Then install tf_trt_models:
$ git clone --recursive https://github.com/NVIDIA-Jetson/tf_trt_models.git
$ cd tf_trt_models
$ ./install.sh
Finally, follow this guide to install the Argus Camera library.
Download GreenMachine:
Clone the repo:
$ git clone https://github.com/NVIDIA-Jetson/GreenMachine
Run GreenMachine:
If you have a projector setup, you will need to calibrate GreenMachine. You only need to run this initially or if you move the camera or projector. Make sure the lighting is dim enough for the projected QR codes to be detected properly.
$ python Calibrate.py
If you have a projector, run GreenMachine normally:
$ python GreenMachine.py
Or without a projector, use --screen
:
$ python GreenMachine.py --screen
In the terminal, you should see the text "Loading...". After a few more seconds, a loading screen should come up on your projector or screen. If these do not happen, refer to Common Errors.
After a few seconds, the loading screen should disappear and you should be able to inference on objects in front of the camera. If not, refer to Common Errors.
Camera not found:
Try these debugging steps:
- Make sure you have a camera that is connected to the Jetson via CSI, not USB.
- Check that the camera is using port 0.
- Disconnect all USB devices that aren't your mouse or keyboard.
- Delete and reinstall GreenMachine and it's dependencies.
Module not found:
Try these debugging steps:
- Uninstall pip modules:
$ sudo pip uninstall opencv-python
$ sudo pip uninstall numpy
$ sudo pip uninstall tensorflow-1.8.0-cp27-cp27mu-linux_aarch64.whl
- Reinstall them:
$ sudo pip install opencv-python
$ sudo pip install numpy
$ sudo pip install tensorflow-1.8.0-cp27-cp27mu-linux_aarch64.whl
- Delete the tf_trt_models folder, then re-install it:
$ rm -rf tf_trt_models
$ git clone --recursive https://github.com/NVIDIA-Jetson/tf_trt_models.git
$ cd tf_trt_models
$ ./install.sh
- Restart
If the model is running slowly:
Re-optimize the model with python GreenMachine.py --build
EnviroNet is a convolutional neural network trained on top of MobileNet SSD v1. It detects and classifies nine different types of objects commonly found in cafeterias and kitchens. You can learn more about EnviroNet here.
EnviroNet Classes:
- cup (cup/soup bowls)
- rutensil (silverware)
- tutensil (plastic utensils)
- container (paper containers and to-go boxes)
- plate (bowls and plates)
- paper (napkins)
- stick (chopsticks and coffee stirrers)
- bottle (water and drink Bottles)
- wrapper (food and candy wrappers)
EnviroNet: Coming to a trash can near you!
Inference is done on a Jetson TX2 with TensorFlow's object detection API and NVIDIA's tf_trt_models.
Benchmarks (Jetson TX2):
- Create model/optimize: 122.5 seconds
- Inference: 40 ms (25.0 fps)
- Inference + Draw bboxes: 45 ms (22.2 fps)
- Inference + Draw bboxes + Render: 51 ms (19.6 fps)
GreenMachine was made by high school interns Karly Hou, Shruthi Jaganathan, and Isaac Wilcove at NVIDIA during the summer of 2018.