summaryrefslogtreecommitdiff
path: root/sec.py
blob: 1db8683ee658f1ab5c61404ee90289ee5848035a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
# A speach transcriber using the google speech recognizer and then dsplaying it on the lcd of a raspberry pi

from rpi_lcd import LCD
fro
import speech_recognition as sr
from time import sleep
import sounddevice 
from motion import comp

r = sr.Recognizer()
lcd = LCD()
mic = sr.Microphone()

# Clearing the lcd before starting the program
lcd.clear()

# Listening to the user's voice and putting it into a variable
def listen_voice():
    global audio
    with mic as source:
        r.adjust_for_ambient_noise(source)
        audio = r.listen(source)
    return audio

# Transcribing the audio to text and printing it out
# Using the google speech recognizer 
# Google speech recognizer does require a internet connection
def recognize_speech(audio):
    error = "400"
    r_error = "401"

    try:
        words = r.recognize_google(audio)
        lcd.text(words, 1)
        print(f"Printing on screen: {words}")
    except sr.UnknownValueError:
        lcd.text(error, 1)
        print(error)
    except sr.RequestError:
        lcd.text(r_error, 1)
        print(r_error)


while True:
    audio = listen_voice()
    recognize_speech(audio)