/seeing_eye

Nvidia Jetson Nano Project

Primary LanguagePython

Seeing Eye

James L. Nesfield, MSBA

1/1/2021

INSPIRATION

My mother is blind. She has a degenerative condition called Retinitis Pigmentosa. There is no cure for this condition at this time. For as long as I can remeber she has had trouble seeing at night and difficulty with peripheral vision. In the last few years her sight has rapidly declined to the point where she can not read or do normal day to day activities. I wanted to develop a tool that would give her back some of her normality in life so she can at least identify some simple objects in her surroundings as well as read any labels or text on them. With that in mind and the Jetson Nano available i set to task to make this tool a reality.

SHOPPING LIST

The shopping list for this project is below with links to the actual items I purchased. The shopping list is broken down into two sections CORE and OPTIONAL. Most of the optional items are things I got that help the workflow but are not really necessary.

CORE

Jetson Nano 2GB Dev Kit: https://www.amazon.com/NVIDIA-Jetson-Nano-Developer-945-13541-0000-000/dp/B08J157LHH/ref=sr_1_3?dchild=1&keywords=jetson+nano+2gb&qid=1609698418&sr=8-3
SD Card: https://www.amazon.com/gp/product/B07G3H5RBT/ref=ppx_yo_dt_b_asin_title_o08_s00?ie=UTF8&psc=1
Electronic Parts Kit: https://www.amazon.com/gp/product/B01IH4VJRI/ref=ppx_yo_dt_b_asin_image_o00_s00?ie=UTF8&psc=1
USB Audio Device: https://www.amazon.com/gp/product/B00XM883BK/ref=ppx_yo_dt_b_asin_title_o01_s00?ie=UTF8&psc=1
Jumper Shunts: https://www.amazon.com/gp/product/B077957RN7/ref=ppx_yo_dt_b_asin_title_o07_s00?ie=UTF8&psc=1
Atx Power Buttons: https://www.amazon.com/gp/product/B07JYX97Y6/ref=ppx_yo_dt_b_asin_title_o07_s02?ie=UTF8&psc=1
USB C Power Supply: https://www.amazon.com/gp/product/B07TYQRXTK/ref=ppx_yo_dt_b_asin_title_o09_s00?ie=UTF8&psc=1
1MP USb Camera: https://www.amazon.com/gp/product/B00UMX3HEG/ref=ppx_yo_dt_b_asin_title_o07_s00?ie=UTF8&psc=1

OPTIONAL

Nano Case: https://www.amazon.com/gp/product/B07TS83WGW/ref=ppx_yo_dt_b_asin_title_o08_s00?ie=UTF8&psc=1
Battery Pack: https://www.amazon.com/gp/product/B07P5ZP943/ref=ppx_yo_dt_b_asin_title_o05_s00?ie=UTF8&psc=1

Various other cabels and widgets are also involved. If I miss something big please comment so I can fix it!

BASE SET UP

Follow the steps in the Nvidia documentation (https://developer.nvidia.com/embedded/learn/get-started-jetson-nano-devkit#write) to set up the Nano. On the build I am working on I used jetpack 4.4.1 found here: https://developer.nvidia.com/embedded/Jetpack. Please note during set up to select the option to auto login for the Nano as i have found it causes other issues down the road to not have such enabled!
Once the Nano is set up follow the instructions in the file nano_setup.txt in this repository which lays out the commands to set up the software needed to run this project. There are some additional things in the set up like tensorflow, tensorflow hub, and juptyer which are not needed to run the application but are useful to build on top of this effort. The set up steps include removing the ubuntu desktop (memory hog) as well as installing GIT LFS to enable downloading the frozen models needed. It goes without saying if you are reading this that you should have some familarity with GIT and GIT LFS.
After setting up the linux packages please follow the GPIO setup instructions at: https://github.com/NVIDIA/jetson-gpio. GPIO is needed later to enable a button to be used to tell the application when to capture an image to process.
At this point you should be ready to go.

GPIO SETUP

This was done as inspired by: https://youtu.be/ehzrPl5cNCc and https://youtu.be/6FNX9XTRWCA

The GPIO set up follows the below schematic:

In lay terms: we are using pins 1, 9, and 15.

  • Pin 1: 3.3 Volt
  • Pin 9: Ground
  • Pin 15: LCD_TE

By recreating this schematic with a bread board and some header wires we end up with the following:

Now we have a GPIO based button that will work witht eh application, provided the Jetson GPIO github instructions were followed correctly.

Next we set up a led light to let us know when the device is ready.

The GPIO set up follows the below schematic:

In lay terms: we are using pins 2, 9, and 23.

  • Pin 2: 5 Volt
  • Pin 9: Ground
  • Pin 23: SPI_1_SCK

By recreating this schematic with a bread board and some header wires we end up with the following:

Now we have a button to tell the device when to capture as well as a light that goes on when the device is ready and turns off when capturing!!

This will NOT be helpful for sight impared individuals but will be helpful for our testing purposes.

For those who are sight impaired I modified the code so as to emit an audible tone using the speaker test function in linux. This was implemented in the working field test prototype I made for my mother that I recently gave her.
I will NOT becovering the deisgn and assembly of the field prototype as that is not in scope for purposes of this documentation.

HOW THE CODE WORKS

I cheated here a bit on the machine learning aspect of this as I am a big proponent of transfer learning and using pretrained models as most models are trainined on large clusters of compute resources on millions of samples which is typically unreaslistic to acheive without significant time and resources.
However: This is not really cheating; in an enterprise or production environment the time to value problem is real as most organizations are not willing to spend limited resources on purely experimental research without aim or a defined exit point in which a product is available to the customers, be it internal or external. There is also a high risk of failure which must be recognized. This is why cloud providers are so successful in creating software as a service in the form of cognitive or AI tools like ocr, text to speech, or the likes as they can be used quickly by the consumer by making a simplified api call.
The design mentality I took here takes such an approach.

The basis for the code is two different opencv tutorials by Adrian RoseBrock of pyimagesearch.


There was also significant coding assistance found via Google which mostly resulted in Stack Overflow threads and posts having the most useful answers on technical issues that occured with the code.
With that acknowledgement let's walk through how this works from the aspect of the entry code containing the calls to the utils/utils.py script containing the lower level code.
**Note:** the lower level code is covered her in a high level detail but for a more indepth understanding I invite you to reviewthe pyimagesearch links above as **Adrian RoseBrock** is awesome at breaking down the concepts and anything I say will basically be quoting or summarizing what he has already said there.

From a highlevel what occurs is that:

  • 1: Code loads the dependencies and the utils/utils.py(utils form here on) as a normal python import.
  • 2: Code sets the default audio out and volume, GPIO pins/signals, implements a keyboard interrupt protocol, and uses os calls to emit a tone when ready.
  • 3: Code enters infinite loop (which can be broken by interrupt).
  • 4: Code uses GPIO signal to determine when capture button is activated to run application workflow.
  • 5: When GPIO signal received code does the following:
  • a: Image is captured from USB Camera via Open CV.
  • b: Image is passed to Object Detection function which use Open CV and the pretained Yolov3 object detection model and results are rerturned to main.
  • c: Image is passed to Text Detection function which uses Open CV, the pretrained EAST model, and Pytesseract.
  • d: Results of Text Detecton are ordered by coordinates so they follow the order they appear in.
  • e: Results are read to user via pyttsx3.

**Lets take a deeper dive and explain what is occuring here:**

TESTING

Testing is quite simple once the gpio pin are set up as above and the code is downloaded and ran.
If the object is in the yolov3 data used to train the model used here it will be detected.
Next if there is text in the object it will be read using the tesseract ocr engine.
Finally a text to voice tool will read the text where the audio signal will be output to a 1/8 inch stereo jack so that any standard set of headphones can be used.

Currently this is in live testing with my mother and further updates are expected!

MORE TO COME