Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/crhung/Voice-Emotion-Detector

Voice Emotion Detector that detects emotion from audio speech using one dimensional CNNs (convolutional neural networks) using keras and tensorflow on Jupyter Notebook.
https://github.com/crhung/Voice-Emotion-Detector

Last synced: 3 months ago
JSON representation

Voice Emotion Detector that detects emotion from audio speech using one dimensional CNNs (convolutional neural networks) using keras and tensorflow on Jupyter Notebook.

Awesome Lists containing this project

README

        

# Speech Emotion Analyzer

* The idea behind creating this project was to build a voice emotion detector that could detect emotions from audio from speech

* It can be used in many business applications for example, this can be used by multiple industries to offer different services like marketing comapny suggesting you to buy products based on your emotions, automotive industry can detect the persons emotions and adjust the speed of autonomous cars as required to avoid any collisions etc.

## Analyzing audio signals
![](images/joomla_speech_prosody.png?raw=true)
©joomla_speech_prosody

### Datasets:
Made use of two different datasets:
1. [RAVDESS](http://neuron.arts.ryerson.ca/ravdess/?f=3).
This dataset includes around 1500 audio file input from 24 different actors. 12 male and 12 female where these actors record short audios in 8 different emotions i.e 1 = neutral, 2 = calm, 3 = happy, 4 = sad, 5 = angry, 6 = fearful, 7 = disgust, 8 = surprised.

Each audio file is named in such a way that the 7th character is consistent with the different emotions that they represent.

2. [SAVEE](http://kahlan.eps.surrey.ac.uk/savee/Download.html).
This dataset contains around 500 audio files recorded by 4 different male actors. The first two characters of the file name correspond to the different emotions that the potray.

## Audio files:
Tested out the audio files by plotting out the waveform and a spectrogram to see the sample audio files.

**Waveform**
![](images/wave.png?raw=true)




**Spectrogram**

![](images/spec.png?raw=true)

## Feature Extraction
The next step involves extracting the features from the audio files which will help our model learn between these audio files.
For feature extraction we make use of the [**LibROSA**](https://librosa.github.io/librosa/) library in python which is one of the libraries used for audio analysis.


![](images/feature.png?raw=true)


* The feature used to extract from are Mel-frequency cepstrum coefficients (MFCCs). This feature is used often used in voice recognition software because of the way MFCCs accurately envelope the the shape of the vocal tract.
* While extracting the features, all the audio files have been sampled starting from 0.5 seconds and then timed for 3 seconds to get equal number of features.
* The sampling rate of each file is doubled to around 44 KHz. This allows each audio samples to get more features which will help classify the audio file while keeping noise at a minimum.
* The audio files were also seperated by emotion and sex.


The extracted features looks as follows:



![](images/feature2.png?raw=true)

These are array of values with lables appended to them.

## Building Models

Since the project is a classification problem, **Convolution Neural Network** seems the obivious choice. We also built **Multilayer perceptrons** and **Long Short Term Memory** models but they under-performed with very low accuracies which couldn't pass the test while predicting the right emotions.




![](images/Model.PNG?raw=true)

Building and tuning a model is a very time consuming process. The idea is to always start small without adding too many layers just for the sake of making it complex. After testing out with layers, the model which gave the max validation accuracy against test data was little more than 70%




![](images/cnn.png?raw=true)

## Predictions

After tuning the model, tested it out by predicting the emotions for the test data. For a model with the given accuracy these are a sample of the actual vs predicted values.




![](images/predict.png?raw=true)

## Testing out with live voices.
In order to test out our model on voices that were completely different than what we have in our training and test data, we recorded our own voices with dfferent emotions and predicted the outcomes using the audiorecorder.ipynb. You can see the results below:
The audio contained a male voice which said **"This coffee sucks"** in a angry tone.


![](images/livevoice.PNG?raw=true)




![](images/livevoice2.PNG?raw=true)

**As you can see that the model has predicted the male voice and emotion accurately.**

## Conclusion
Building the model was a challenging task as it involved lot of trail and error methods, tuning etc. The model is very well trained to distinguish between male and female voices and it distinguishes with 100% accuracy. The model is still being tuned to detect emotions with more than 70% accuracy which is achievable by increasing the size of the dataset.