/ml_subtitle_align

Compute audio alignment for talk transcripts.

Primary LanguagePythonMIT LicenseMIT

Subtitle Alignment

The aim of this project is to compute time alignment information between (English) spoken word audio and a provided transcript of the same audio. This is done by using an acoustic model trained on a large number of TED talks and performing a global optimization procedure with the model predictions as input. A much more in-depth discussion of this process can be found in ml_subtitle_align/doc.

This project is a mini research project created in fulfillment of requirements for the course "Fundamentals of Machine Learning" at Heidelberg University in the winter semester 2017/18.

Getting started

This repository contains all necessary code for both training and prediction. To perform training, you will need to follow the procedure outlined under "Data aquisition" to download the necessary audio material (about 40GB) and extract MFCC features from it (another 40GB of disk space required).

For prediction, you can use one of the pretrained models located in ml_subtitle_align/training_data/run_*/train/. Simple prediction for an audio snippet can be performed by executing snippet_demo.py. To compute alignment information for a whole TED-talk, choose one of the example talks in ml_subtitle_align/data/audio and execute predict.py with the required arguments. Note, that these talks were not part of the training dataset.

Prerequisites

The code in this repo is expected to be run with Python 3.*. Additional library requirements are listed in requirements.txt. You will also need to install ffmpeg for extracting audio from fetched video files. If you wish to demo subtitle synchronization, you will also need to have VLC installed.

Data aquisition

We use TED-talk transcripts and subtitles as well as their audio recordings. The audio in this dataset is very high-quality and consists largely of clean spoken words.

This kaggle dataset contains structural metadata about TED talks such as title, url and even transcripts of each talk. After downloading the kaggle dataset and unpacking it to ml_subtitle_align/data/kaggle/ you can execute mine_subtitles.py which will fetch the subtitles incrementally.

Once all previous steps have (at least partially) finished, you can execute download_audio.py which will incrementally fetch all required MP3 audio files from TED and save them into ml_subtitle_align/data/audio. Consequently, extract_features.py will extract the audio features from MP3 and WAV files in ml_subtitle_align/data/audio and save the resulting files in ml_subtitle_align/data/audio_features.

More specifically, python_speech_features is used to extract MFCC features with a 25ms analysis window and 10ms step between successive windows.

Consequently, you can run generate_metamap.py which will generate necessary metadata.

Training

Create a training_config.json and a hardware_config.json from the provided default examples. In this config file, you can specify which model to train (options are: "conv_lstm", "dense_conv", "deep_conv", "simple_conv") as well as which loss function (options are: "softmax", "sigmoid_cross_entropy", "reg_hit_top") and optimization settings to use.

Each training run generates a directory in ml_subtitle_align/training_data/ as its output.

Prediction

You can either perform prediction for a single audio snippet using snippet_demo.py or predict alignment for a whole TED talk by using predict.py. Both scripts have help menus to describe necessary parameters.

License

All python code in this repository is available under an MIT license. All files in ml_subtitle_align/data/ and ml_subtitle_align/snippet_demo/ are copies or derivatives of content owned by TED and are hence subject to additional restrictions.