MassivelyMultilingualTTS / run_model_downloader.py
Flux9665's picture
use explicit code instead of relying on release download
9e275b8
raw
history blame
3.73 kB
import os
import urllib.request
from Utility.storage_config import MODELS_DIR
def report(block_number, read_size, total_size):
if block_number % 1000 == 0:
return_to_front = '\b' * 52
percent = round(((block_number * read_size) / total_size) * 100)
print(f"{return_to_front}[{'β–ˆ' * (percent // 2)}{'.' * (50 - (percent // 2))}]", end='')
if block_number * read_size >= total_size:
return_to_front = '\b' * 52
print(f"{return_to_front}Download complete!\n")
def download_models():
#############
print("Downloading Aligner Model")
os.makedirs(os.path.join(MODELS_DIR, "Aligner"), exist_ok=True)
filename, headers = urllib.request.urlretrieve(
url="https://github.com/DigitalPhonetics/IMS-Toucan/releases/download/v3.0/aligner.pt",
filename=os.path.abspath(os.path.join(MODELS_DIR, "Aligner", "aligner.pt")),
reporthook=report)
#############
print("Downloading Multilingual ToucanTTS Model")
os.makedirs(os.path.join(MODELS_DIR, "ToucanTTS_Meta"), exist_ok=True)
filename, headers = urllib.request.urlretrieve(
url="https://github.com/DigitalPhonetics/IMS-Toucan/releases/download/v3.0/ToucanTTS_Meta.pt",
filename=os.path.abspath(os.path.join(MODELS_DIR, "ToucanTTS_Meta", "best.pt")),
reporthook=report)
#############
print("Downloading Vocoder")
os.makedirs(os.path.join(MODELS_DIR, "Vocoder"), exist_ok=True)
filename, headers = urllib.request.urlretrieve(
url="https://github.com/DigitalPhonetics/IMS-Toucan/releases/download/v3.0/Vocoder.pt",
filename=os.path.abspath(os.path.join(MODELS_DIR, "Vocoder", "best.pt")),
reporthook=report)
#############
print("Downloading Embedding Model")
os.makedirs(os.path.join(MODELS_DIR, "Embedding"), exist_ok=True)
filename, headers = urllib.request.urlretrieve(
url="https://github.com/DigitalPhonetics/IMS-Toucan/releases/download/v3.0/embedding_function.pt",
filename=os.path.abspath(os.path.join(MODELS_DIR, "Embedding", "embedding_function.pt")),
reporthook=report)
#############
print("Downloading Embedding GAN")
os.makedirs(os.path.join(MODELS_DIR, "Embedding"), exist_ok=True)
filename, headers = urllib.request.urlretrieve(
url="https://github.com/DigitalPhonetics/IMS-Toucan/releases/download/v3.0/embedding_gan.pt",
filename=os.path.abspath(os.path.join(MODELS_DIR, "Embedding", "embedding_gan.pt")),
reporthook=report)
#############
print("Downloading Codec Model")
os.makedirs("Preprocessing/Codec", exist_ok=True)
filename, headers = urllib.request.urlretrieve(
url="https://huggingface.co/Dongchao/AcademiCodec/resolve/main/encodec_16k_320d.pth",
filename=os.path.abspath(os.path.join("Preprocessing/Codec", "encodec_16k_320d.pt")),
reporthook=report)
#############
print("Downloading ASP lookup")
os.makedirs("Preprocessing/multilinguality", exist_ok=True)
filename, headers = urllib.request.urlretrieve(
url="https://github.com/DigitalPhonetics/IMS-Toucan/releases/download/v3.0/asp_dict.pkl",
filename=os.path.abspath(os.path.join("Preprocessing/multilinguality", "asp_dict.pkl")),
reporthook=report)
#############
print("Downloading Audioseal Model")
os.makedirs("Models/audioseal", exist_ok=True)
filename, headers = urllib.request.urlretrieve(
url="https://github.com/DigitalPhonetics/IMS-Toucan/releases/download/v3.0/audioseal.pth",
filename=os.path.abspath(os.path.join("Models/audioseal", "generator.pth")),
reporthook=report)
if __name__ == '__main__':
download_models()