You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
rafaelvalle 12ab5ba89c model.py: setting weight initialization to xavier uniform 6 years ago
filelists changing structure for better organization 6 years ago
text text/: adding Keith Itos text pre-processing 6 years ago
Dockerfile Dockerfile: adding dockerfile 6 years ago
LICENSE Update license such that it appears on repo fron tpage 6 years ago
README.md README.md: being explicit about action 6 years ago
audio_processing.py adding python files 6 years ago
data_utils.py data_utils.py: adding support for loading mel from disk 6 years ago
demo.wav adding demo.wav file 6 years ago
distributed.py adding python files 6 years ago
fp16_optimizer.py adding python files 6 years ago
hparams.py hparams.py: commenting n_frames_per_step to indicate that currently only 1 frame per step is supported now 6 years ago
inference.ipynb ipynb typo 6 years ago
layers.py adding python files 6 years ago
logger.py adding python files 6 years ago
loss_function.py adding python files 6 years ago
loss_scaler.py loss_scaler.py: patching loss scaler for compatibility with current pytorch 6 years ago
model.py model.py: setting weight initialization to xavier uniform 6 years ago
multiproc.py adding python files 6 years ago
plotting_utils.py adding python files 6 years ago
requirements.txt requirements.txt: updating tensorflow requirements 6 years ago
stft.py adding python files 6 years ago
tensorboard.png tensorboard.png: adding tensorboard image 6 years ago
train.py hparams.py: adding use saved learning rate param 6 years ago
utils.py mask utils update for 0.4 cuda 6 years ago

README.md

Tacotron 2 (without wavenet)

Tacotron 2 PyTorch implementation of Natural TTS Synthesis By Conditioning Wavenet On Mel Spectrogram Predictions.

This implementation includes distributed and fp16 support and uses the LJSpeech dataset.

Distributed and FP16 support relies on work by Christian Sarofeen and NVIDIA's Apex Library.

Alignment, Predicted Mel Spectrogram, Target Mel Spectrogram

Download demo audio trained on LJS and using Ryuchi Yamamoto's pre-trained Mixture of Logistics wavenet
"Scientists at the CERN laboratory say they have discovered a new particle."

Pre-requisites

  1. NVIDIA GPU + CUDA cuDNN

Setup

  1. Download and extract the LJ Speech dataset
  2. Clone this repo: git clone https://github.com/NVIDIA/tacotron2.git
  3. CD into this repo: cd tacotron2
  4. Update .wav paths: sed -i -- 's,DUMMY,ljs_dataset_folder/wavs,g' filelists/*.txt
    • Alternatively, set load_mel_from_disk=True in hparams.py and update mel-spectrogram paths
  5. Install pytorch 0.4
  6. Install python requirements or build docker image
    • Install python requirements: pip install -r requirements.txt
    • OR
    • Build docker image: docker build --tag tacotron2 .

Training

  1. python train.py --output_directory=outdir --log_directory=logdir
  2. (OPTIONAL) tensorboard --logdir=outdir/logdir

Multi-GPU (distributed) and FP16 Training

  1. python -m multiproc train.py --output_directory=outdir --log_directory=logdir --hparams=distributed_run=True,fp16_run=True

Inference

  1. jupyter notebook --ip=127.0.0.1 --port=31337
  2. load inference.ipynb

nv-wavenet: Faster than real-time wavenet inference

Acknowledgements

This implementation uses code from the following repos: Keith Ito, Prem Seetharaman as described in our code.

We are inspired by Ryuchi Yamamoto's Tacotron PyTorch implementation.

We are thankful to the Tacotron 2 paper authors, specially Jonathan Shen, Yuxuan Wang and Zongheng Yang.