Git Product home page Git Product logo

vits's Introduction

VITS: Conditional Variational Autoencoder with Adversarial Learning for End-to-End Text-to-Speech

Jaehyeon Kim, Jungil Kong, and Juhee Son

In our recent paper, we propose VITS: Conditional Variational Autoencoder with Adversarial Learning for End-to-End Text-to-Speech.

Several recent end-to-end text-to-speech (TTS) models enabling single-stage training and parallel sampling have been proposed, but their sample quality does not match that of two-stage TTS systems. In this work, we present a parallel end-to-end TTS method that generates more natural sounding audio than current two-stage models. Our method adopts variational inference augmented with normalizing flows and an adversarial training process, which improves the expressive power of generative modeling. We also propose a stochastic duration predictor to synthesize speech with diverse rhythms from input text. With the uncertainty modeling over latent variables and the stochastic duration predictor, our method expresses the natural one-to-many relationship in which a text input can be spoken in multiple ways with different pitches and rhythms. A subjective human evaluation (mean opinion score, or MOS) on the LJ Speech, a single speaker dataset, shows that our method outperforms the best publicly available TTS systems and achieves a MOS comparable to ground truth.

Visit our demo for audio samples.

We also provide the pretrained models.

** Update note: Thanks to Rishikesh (ऋषिकेश), our interactive TTS demo is now available on Colab Notebook.

VITS at training VITS at inference
VITS at training VITS at inference

Pre-requisites

  1. Python >= 3.6
  2. Clone this repository
  3. Install python requirements. Please refer requirements.txt
    1. You may need to install espeak first: apt-get install espeak
  4. Download datasets
    1. Download and extract the LJ Speech dataset, then rename or create a link to the dataset folder: ln -s /path/to/LJSpeech-1.1/wavs DUMMY1
    2. For mult-speaker setting, download and extract the VCTK dataset, and downsample wav files to 22050 Hz. Then rename or create a link to the dataset folder: ln -s /path/to/VCTK-Corpus/downsampled_wavs DUMMY2
  5. Build Monotonic Alignment Search and run preprocessing if you use your own datasets.
# Cython-version Monotonoic Alignment Search
cd monotonic_align
python setup.py build_ext --inplace

# Preprocessing (g2p) for your own datasets. Preprocessed phonemes for LJ Speech and VCTK have been already provided.
# python preprocess.py --text_index 1 --filelists filelists/ljs_audio_text_train_filelist.txt filelists/ljs_audio_text_val_filelist.txt filelists/ljs_audio_text_test_filelist.txt 
# python preprocess.py --text_index 2 --filelists filelists/vctk_audio_sid_text_train_filelist.txt filelists/vctk_audio_sid_text_val_filelist.txt filelists/vctk_audio_sid_text_test_filelist.txt

Training Exmaple

# LJ Speech
python train.py -c configs/ljs_base.json -m ljs_base

# VCTK
python train_ms.py -c configs/vctk_base.json -m vctk_base

Inference Example

See inference.ipynb

vits's People

Contributors

qiaolinwang avatar alexandajerry avatar haveyouwantto avatar

Stargazers

 avatar  avatar YuBaD avatar  avatar  avatar 睐笃 avatar yaoxiaoangry avatar I am noob avatar  avatar gaoyamimi avatar Tindalosophia.  avatar AR avatar  avatar Doiiars avatar PengChaoJay avatar Proton avatar  avatar Bojie Li avatar 东宇 avatar Kingfo avatar  avatar 以尘寻鹿 avatar レモン avatar Zihao Zhang avatar Jianzhuang Li avatar asdfs avatar YaoSiQian avatar Elysia avatar Xupeng (Tony) Tong avatar ^薄荷布丁^ avatar  avatar yahaha99678 avatar Endless-Bun01-index avatar Desmond Rohan avatar Qihuan Jun avatar  avatar DarkstarXD avatar  avatar yuko1101 avatar Uranai avatar starkwang avatar  avatar 殷雅俊 avatar Xiagrui Zeng avatar  avatar  avatar Topi avatar 钟顺民 avatar  avatar  avatar mmor avatar  avatar 半颗白菜 avatar Xing Yu avatar  avatar Aria F avatar  avatar YzwhY avatar  avatar  avatar  avatar  avatar  avatar Ruoting Wu  avatar 张乐平 avatar JS00000 avatar  avatar  avatar  avatar Sean Liu avatar  avatar 把梦丢在海里 avatar  avatar Chris Xiong avatar Ze Liu avatar Xuanqiang Liao avatar 桜夢 瑶 avatar  avatar  avatar Cen Linze avatar  avatar Wang avatar  avatar Zhang Jin Yuan avatar 一一世开_小冰科技 avatar  avatar  avatar rain avatar  avatar Kuzan pung avatar hakurei_233 avatar  avatar Cherry Mobius avatar Yuda avatar player avatar LIU Jiahe avatar KY avatar 翎风 avatar cykgle avatar  avatar

Watchers

shicz86 avatar iceorange avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.