End-to-End Speech Recognition Guide in Python
Speech recognition is the process of enabling computers to identify and transcript appropriately from human voices or any other sounds. Speech is the best and most widely used means of communication in the world. People rely on it to pass messages to one another for first-hand information. <!--more--> Companies like Google have made work easier by implementing Cloud Speech-to-Text to convert speech to text. Through this, speech recognition has helped us save time from typing things. It has also given us an easy way to interact and communicate with our devices without having to write a line of code.
Companies like Amazon-Alexa use speech recognition for easy navigation to their products. Speech recognition has helped the disabled, children, and visually impaired to interact with their system efficiently since no GUI is needed.
When building a Python application, one needs to incorporate speech recognition in their work to allow easier interaction between the user and the system providing better accessibility.
Let's learn more about speech recognition - how it works, applications that use speech recognition, and simple implementation in Python to recognize speeches.
Table of contents
- Prerequisites
- Working principle of speech recognition
- Packages in speech recognition
- Application of speech recognition
- Open-source project for speech to text
- Conclusion
Prerequisites
For one to understand this tutorial better, the reader needs to have the following:
- A good understanding of Machine learning.
- Basic knowledge in Python programming.
- Have Jupyter notebook installed and know how to use it.
- Have Python installed on a machine.
Working principle of speech recognition
Speech recognition was first developed in Bell Labs, in the year 1952. Three researchers developed the system Audrey
that uses a single speaker for digit recognition - the evolution continued, and more inventions were developed. Now, speech recognition comes built-in with many packages that can understand many languages.
The speech recognition working principle entails converting speech to electrical signals using a microphone. The signals are digitized to digital data that can be understood by the machine. After digitizing, many models have been used to translate the audio data to text data.
The modern speech recognition relies on Hidden Markov Model approach (HMM) which works on the assumption that speech signal when viewed on a short timescale (like 10 milliseconds), it appears to be a stagnant process - meaning there is no change in the waves patterns. The HMM is used in finding temporal patterns and improving accuracy.
As a programmer, let's not worry about the working principles of speech recognition, since numerous services working with speech recognition are available free online for developers than APIs. One just needs to install the package to start recognizing sounds.
Packages in speech recognition
Since the implementation of speech recognition, there are several packages available that deal with the speech exists on Python manager PyPI.
We will have a look at a few of them:
- Apiai
- SpeechRecognition
- CMU sphinx
- wit
- Google-cloud-speech
- watson-developer-cloud
- pocket sphinx
- Assembyai
The speech recognition package works the best when dealing with or developing a speech recognition application.
Packages like Apiais
offer additional functionalities for NLP (Natural Language Processing) that are used for identifying the intent of speakers.
CMU sphinx
designed with low resource platforms does focus on some fieldwork application creation.
Google Cloud speech offers speech to text messaging.
In addition, speech recognition offers simple audio processing and easy microphone accessibility.
We will use the SpeechRecognition package for the following reasons:
- Saves audio data into an audio file.
- Simple understandable results.
- Speech can be recognized easily by a microphone.
- Gives an easy way to translate audio files.
How to implement speech recognition
Installation
Run the command to install the speech recognition package:
pip install speechrecognition
Install PyAudio
for accessing the microphone from the device using the command below:
pip install pyaudio
Check the version of installed speech recognition using the command below:
import speech_recognition as sp
print(sp.__version__)#sp is how you have assigned the variable
Building the recognizer class
To set the conversion of audio data to text data, we will focus on the Recognizer
class.
The importance of setting the recognizer class is to create an environment (object) for speech to be recognized in our application.
Run the command below to set the recognizer class:
recognizer = sp.Recognizer()
Setting the threshold value
The threshold value is a value that determines the loudness of an audio file.
To determine the energy threshold of an audio file, consider the ideal energy of audio files which is equivalent to 300
(recommended by SpeechRecognition
library), and works best within that limit when dealing with the audio files.
When working on audio data, increasing the energy threshold does nothing but only improves speech recognition. When values exceed the energy threshold of 300
, we consider them to be speech.
However, when they go below that barrier, they are deemed silent or no speech is found.
To set the threshold, we run the command below:
recognizer.energy_threshold = 300
Speech recognition methods
The methods below are used for recognizing speech from the audio data using different APIs:
recognize_houndify()
- Houndify by SoundHound.recognize_ibm()
- IBM speech-to-text.recognize_sphinx()
- CMU Sphinx (works after installing PocketSphinx).recognize_google()
- Google web speech API.recognize_google_cloud()
- Google Cloud Speech (need to install google-cloud-speech package).
The recognize_sphinx()
can work offline with the CMU Sphinx engine. But, other functions require a stable internet connection.
Google has a free API recognize_google()
method, that runs on its own without the help of any API. One disadvantage in that is, it gives a limit when trying to process audio files that take a long time during processing.
Processing audio
When processing an audio file, due to the wrong data type format of the audio file, there are chances of error to occur.
For this, the audio file should be processed as shown below:
import speech_recognition as sp
# get audio from the microphone
data = sp.Recognizer()
with sp.Microphone() as start:
print("speak up!")
audio = data.listen(start)
# write audio to a WAV file
with open("microphone-results.wav", "wb") as f:
f.write(audio.get_wav_data())
You can find the code here.
Audio conversion
import speech_recognition as sr
recognizer = sr.Recognizer()
audio_file_ = sr.AudioFile("audio_myfile.wav")#input the name of your audio file to be processed "myfile.wav".
This code converts audio to audio data with help of record()
.
#specify the source of the audio data to be converted.
with audio_file as start:
audio_file = recognizer.record(start)
recognizer.recognize_google(audio_data = audio_file)
Parameters used in record
include:
Duration
Duration is the time taken for an action to start or complete. It is used in speech recognition to specify the time taken when working with audio data.
For example, the line code states that "I like traveling and nature walk". Let's say that, the sentence must be read in 6 seconds (when it's not possible to read in 6 seconds). Thereby, we restrict the speech recognition to a specific duration using the code below:
with audio_file_ as start:
audio_file = recognizer.record(source, duration = 0.06)#specify the duration in seconds 0.06
result = recognizer.recognize_google(audio_data=audio_file)
print(result)
Output:
"I like traveling"
Offset
Offset is used to crop audio data.
For example, when you want to listen to the audio for 3 seconds, you set the offset to be 3.
with audio_file_start:
audio_file = recognizer.record(start, offset=3.0)
result = recognizer.recognize_google_cloud(audio_data = audio_file)
print(result)
Output:
"and nature walk"
Open-source project for speech to text
DeepSpeech
This is an open-source embedded speech-to-text engine that runs on real-time devices with higher power GPU servers to those with less power like Raspberry. Mostly exists and runs on pre-trained machine models.
For further information, you can read here.
SpeechRecognition
SpeechRecognition is also an open-source project having several engines and APIs that are freely available offline.
For more information, read this.
Leon
Leon is an open-source project that lives on a server and performs some tasks as directed by the users. It can as well be configured to operate offline as well.
For documentation, read this.
Wav2letter
Developed by Facebook researchers that work on end-to-end auto-switch speech recognition.
More information can be found here.
Espnet
Espnet is an end-to-end speech processing toolkit that covers text to speech, speech translation, spoken language, and the rest.
For more information, read this.
Few other open-source projects include:
Conclusion
After going through this article, you will get to know what speech recognition is, where it is used in real life, and it's working principles as well.
Furthermore, you will gain knowledge on various open-source projects where you can configure and make your speech recognition application. Also, we have covered the implementation using one of the libraries in detail.
Happy coding!
Peer Review Contributions by: Srishilesh P S