Skip to content

sarulab-speech/UTMOSv2

Repository files navigation

utmosv2

UTMOSv2: UTokyo-SaruLab MOS Prediction System

🎤✨ Official implementation of ✨🎤
The T05 System for The VoiceMOS Challenge 2024:
Transfer Learning from Deep Image Classifier to Naturalness MOS Prediction of High-Quality Synthetic Speech
🏅🎉 accepted by IEEE Spoken Language Technology Workshop (SLT) 2024. 🎉🏅

ꔫ・-・ꔫ・-・ꔫ・-・ꔫ・-・ꔫ・-・ꔫ・-・ꔫ・-・ꔫ

✨  UTMOSv2 achieved 1st place in 7 out of 16 metrics  ✨
✨🏆    and 2nd place in the remaining 9 metrics    🏆✨
✨    in the VoiceMOS Challenge 2024 Track1!    ✨


🚀 Quick Prediction

✨ You can easily use the pretrained UTMOSv2 model!

Note

To clone the repository and use the pretrained UTMOSv2 model, make sure you have git lfs installed. If it is not installed, you can follow the instructions at https://git-lfs.github.com/ to install it.

🛠️ Using in your Python code 🛠️

✨⚡️ With the UTMOSv2 library, you can easily integrate it into your Python code, ⚡️✨
✨ allowing you to quickly create models and make predictions with minimal effort!! ✨

If you want to make predictions using the UTMOSv2 library, follow these steps:

  1. Install the UTMOSv2 library from GitHub

    # Prevents LFS files from being temporarily downloaded during the installation process
    GIT_LFS_SKIP_SMUDGE=1 pip install git+https://github.com/sarulab-speech/UTMOSv2.git
  2. Make predictions

    • To predict the MOS of a single .wav file:

      import utmosv2
      model = utmosv2.create_model(pretrained=True)
      mos = model.predict(input_path="/path/to/wav/file.wav")
    • To predict the MOS of all .wav files in a folder:

      import utmosv2
      model = utmosv2.create_model(pretrained=True)
      mos = model.predict(input_dir="/path/to/wav/dir/")

Note

Either input_path or input_dir must be specified, but not both.

📜 Using the inference script 📜

If you want to make predictions using the inference script, follow these steps:

  1. Clone this repository and navigate to UTMOSv2 folder

    git clone https://github.com/sarulab-speech/UTMOSv2.git
    cd UTMOSv2
  2. Install Package

    pip install --upgrade pip  # enable PEP 660 support
    pip install -e .[optional] # install with optional dependencies
  3. Make predictions

    • To predict the MOS of a single .wav file:

      python inference.py --input_path /path/to/wav/file.wav --out_path /path/to/output/file.csv
    • To predict the MOS of all .wav files in a folder:

      python inference.py --input_dir /path/to/wav/dir/ --out_path /path/to/output/file.csv

Note

If you are using zsh, make sure to escape the square brackets like this:

pip install -e '.[optional]'

Tip

If --out_path is not specified, the prediction results will be output to the standard output. This is particularly useful when the number of files to be predicted is small.

Note

Either --input_path or --input_dir must be specified, but not both.


Note

These methods provide quick and simple predictions. For more accurate predictions and detailed usage of the inference script, please refer to the inference guide.

🤗 You can try a simple demonstration on Hugging Face Space: Hugging Face Spaces

⚒️ Train UTMOSv2 Yourself

If you want to train UTMOSv2 yourself, please refer to the training guide. To reproduce the training as described in the paper or used in the competition, please refer to this document.

📂 Used Datasets

Details of the datasets used in this project can be found in the datasets documentation.

🔖 Citation

If you find UTMOSv2 useful in your research, please cite the following paper:

@inproceedings{baba2024utmosv2,
  title     = {The T05 System for The {V}oice{MOS} {C}hallenge 2024: Transfer Learning from Deep Image Classifier to Naturalness {MOS} Prediction of High-Quality Synthetic Speech},
  author    = {Baba, Kaito and Nakata, Wataru and Saito, Yuki and Saruwatari, Hiroshi},
  booktitle = {IEEE Spoken Language Technology Workshop (SLT)},
  year      = {2024},
}