/tensorflow-speech-recognition

Speech recognition using google's tensorflow deep learning framework, sequence-to-sequence neural networks

Primary LanguagePython

Tensorflow Speech Recognition

Speech recognition using google's tensorflow deep learning framework, sequence-to-sequence neural networks and keras

Replaces caffe-speech-recognition, see there for training data.

Update: Sphinx starts using tensorflow LSTMs

Extensions to current tensorflow probably needed:

  • Sliding Window GPU implementation
  • FFT / speech feature extraction preprocessing ( or same model with pretraining?)
  • Continuous seq2seq adaptation
  • Modular graphs/models + persistance

Ultimate goal: Create a decent standalone speech recognition for Linux etc. Some people say we have the models but not enough training data. We disagree: There is plenty of training data (100GB here, on Gutenberg, synthetic Text to Speech snippets, Movies with transcripts, YouTube with captions etc etc) we just need a simple yet powerful model. It's only a question of time...

Collaborators wanted! We are in the process of tackling this project in seriousness. Drop an email to info@pannous.com if you want to join the party, no matter your background.

We are still in the planning phase! See train.py for the suggested general architecture. You can contribute right away by discussing or implementing one of the (easy) train_... methods.

** Getting started ** pip install -r requirements.txt ./train.sh ./record.py

Fun tasks for newcomers

  • Data Augmentation : create on-the-fly modulation for our data: increase the speech frequency, add background noise, alter the pitch etc,...
  • Create a matrix auto encoder: the current autoencoder takes a vector as input. each of the easy to add one dimension to autoencode spectrograph files preserving the axis information.
  • Modular persistance: It is important that we have a mechanism to persist and load subsets of the whole model, and to make it extensible on demand. So far the Graph.load and Saver.load mechanisms are insufficient for that. Todo: use keras graph for that?