/Smart-glass-for-blind-people-using-raspberry-pi

The goal of this project is to use the Raspberry Pi to assist the blind. This system scans the environment for recognizable objects, pinpoints them, and then estimates the distance between the user and each object.

Primary LanguagePythonApache License 2.0Apache-2.0

GitHub all releases GitHub

Smart-glass-for-blind-people-using-raspberry-pi

Brief Description

This approach examines the environment for potential threats along a walk path, including the distance to the object and the type of object, and notifies the user of the danger, allowing the user to move around freely without continual monitoring. After the model detects the object, an algorithm tracks the distance to the selected user and provides the user with the necessary information required to process his environment. The glass's camera collects data from the user's surroundings and delivers it to the model, which scans it and gives input on probable directions.

Block Diagram of Proposed System

image

Explanation of Working Concept (code)

CODE EXPLANATION

This python script runs the main activity of the system. This code is majorly broken into three parts:

  1. Object detection
  2. Distance estimation
  3. Audio playback

This script employs the model to determine whether or not a known obstacle exists (cars and humans in this case). Because this system uses two cameras, detection must take place on both ends of the cameras.

A function called depth is used to estimate distance. For compilation, this method accepts the left and right picture frames. The object detection function is then checked to see if an object has been detected. When an object is discovered, this function sends certain arguments to the triangulation script, which calculates and returns the estimated depth.

After the depth has been computed, another function called audio is called into action. This method takes the depth, converts it to a sentence, and then converts it to audio. The audio is then played for the blind to hear.

How to install and use

First to train your model, check out this guide ->https://github.com/EdjeElectronics/TensorFlow-Lite-Object-Detection-on-Android-and-Raspberry-Pi#part-1---how-to-train-convert-and-run-custom-tensorflow-lite-object-detection-models-on-windows-10

His guide also helps you setup your raspiberry pi configurations and all the necessary installations you need to carry a similar project -> https://github.com/EdjeElectronics/TensorFlow-Lite-Object-Detection-on-Android-and-Raspberry-Pi/blob/master/Raspberry_Pi_Guide.md.

After following his guide copy the "TFLite_depth_detection_webcam.py" file and replace with his

btn = Button(24)        # GPIO 24 (pin # 18)
B = 4               #Distance between the cameras [cm]

The project needs a button to start the program, you may want to change the GPIO or set to this exact button The B value also needs to be edited incase you may change the distance between your camera's

def audio(depth):
    string = "A human is "
    away = " meters away "
    depth = int(depth)
    depth = str(depth)
    depth = string+depth+away
    print(depth)
    language = 'en'
    
    myobj = gTTS(text=depth, lang=language, slow=False)
    
    myobj.save("depth.mp3")
    
    music = pyglet.resource.media("depth.mp3")
    music.play()

This code section may be edited as your implementation sees fit. Here i used GTTS and pyglet to convert the text to speech and play it back for the user.

Implementation of Design

image

Prove of working Concept

image image

Estimated Cost of project

Note:

This cost was taken at March, 2022 in the nigerian local currency

S/No Components Quantity Unit Price (N) Total Price (N)
1 Raspberry Pi – 2gb 1 N 34,000 N34,000
2 8MP USB Camera 2 N 17,000 N 34,000
4 Vero Board 1 N 250 N 250
5 4- piece raspberry pi heat sink 1 N 800 N 800
6 Raspberry pi case 1 N 2500 N 2500
7 Lipo 18650 Battery 2 1500 3000
8 18650 1S Lipo battery holder 2 300 600
9 Miscellaneous (shipping and others) N22,000
TOTAL N 97,150

How to contribute

This code is not fully optimised for the raspberry pi as the CPU takes a massive drop in performance when the camera's disparity's are linked. As of this code both camera's are separated.

The initial plan for the project was to implement both distance estimation and path finding, to bring out the features of the raspberry pi. This plan unfortunately fell short due to it's limitations and my inability to move around this problem.

https://github.com/bwalsh0/Stereo-Camera-Path-Planning. This implementation was an inspiration for me, anyone who wants to implement the pathfinding feature may use his work.

Note

The raspberry pi isnt the best hardware to run this project as it doesn't have TPU, some processes couldn't be tested and the hardware runs slowly.

This is just to show the potential of using a more suitable hardware and running the processes on it.

note that some edits will have to be done to make the code efficient on a better device (hardware). i.e making the two camera's read distance better and more optimally.

You can read more from: https://www.researchgate.net/publication/362345190_DESIGN_AND_IMPLEMENTATION_OF_SMART_GLASSES_FOR_BLIND_PEOPLE_-_Using_Raspberry_PI

Special Mentions

https://github.com/EdjeElectronics

https://github.com/bwalsh0