voice-changer/server/downloader/WeightDownloader.py

136 lines
5.1 KiB
Python
Raw Normal View History

2023-06-16 10:49:55 +03:00
import os
from concurrent.futures import ThreadPoolExecutor
2023-06-17 09:35:43 +03:00
from downloader.Downloader import download
from mods.log_control import VoiceChangaerLogger
2023-06-16 10:49:55 +03:00
from voice_changer.utils.VoiceChangerParams import VoiceChangerParams
from Exceptions import WeightDownladException
logger = VoiceChangaerLogger.get_instance().getLogger()
2023-07-26 11:04:55 +03:00
2023-06-16 10:49:55 +03:00
def downloadWeight(voiceChangerParams: VoiceChangerParams):
2023-07-07 21:18:23 +03:00
content_vec_500_onnx = voiceChangerParams.content_vec_500_onnx
2023-06-16 10:49:55 +03:00
hubert_base = voiceChangerParams.hubert_base
hubert_base_jp = voiceChangerParams.hubert_base_jp
hubert_soft = voiceChangerParams.hubert_soft
nsf_hifigan = voiceChangerParams.nsf_hifigan
crepe_onnx_full = voiceChangerParams.crepe_onnx_full
crepe_onnx_tiny = voiceChangerParams.crepe_onnx_tiny
2023-07-15 03:17:19 +03:00
rmvpe = voiceChangerParams.rmvpe
2023-08-26 07:48:03 +03:00
rmvpe_onnx = voiceChangerParams.rmvpe_onnx
2023-06-16 10:49:55 +03:00
2023-07-26 11:04:55 +03:00
weight_files = [content_vec_500_onnx, hubert_base, hubert_base_jp, hubert_soft,
nsf_hifigan, crepe_onnx_full, crepe_onnx_tiny, rmvpe]
2023-06-16 10:49:55 +03:00
# file exists check (currently only for rvc)
downloadParams = []
if os.path.exists(hubert_base) is False:
downloadParams.append(
{
"url": "https://huggingface.co/ddPn08/rvc-webui-models/resolve/main/embeddings/hubert_base.pt",
"saveTo": hubert_base,
"position": 0,
}
)
if os.path.exists(hubert_base_jp) is False:
downloadParams.append(
{
"url": "https://huggingface.co/rinna/japanese-hubert-base/resolve/main/fairseq/model.pt",
"saveTo": hubert_base_jp,
"position": 1,
}
)
if os.path.exists(hubert_soft) is False:
downloadParams.append(
{
"url": "https://huggingface.co/wok000/weights/resolve/main/ddsp-svc30/embedder/hubert-soft-0d54a1f4.pt",
"saveTo": hubert_soft,
"position": 2,
}
)
if os.path.exists(nsf_hifigan) is False:
downloadParams.append(
{
"url": "https://huggingface.co/wok000/weights/resolve/main/ddsp-svc30/nsf_hifigan_20221211/model.bin",
"saveTo": nsf_hifigan,
"position": 3,
}
)
nsf_hifigan_config = os.path.join(os.path.dirname(nsf_hifigan), "config.json")
if os.path.exists(nsf_hifigan_config) is False:
downloadParams.append(
{
"url": "https://huggingface.co/wok000/weights/raw/main/ddsp-svc30/nsf_hifigan_20221211/config.json",
"saveTo": nsf_hifigan_config,
"position": 4,
}
)
2023-07-19 04:20:30 +03:00
nsf_hifigan_onnx = os.path.join(os.path.dirname(nsf_hifigan), "nsf_hifigan.onnx")
if os.path.exists(nsf_hifigan_onnx) is False:
downloadParams.append(
{
"url": "https://huggingface.co/wok000/weights/resolve/main/ddsp-svc30/nsf_hifigan_onnx_20221211/nsf_hifigan.onnx",
"saveTo": nsf_hifigan_onnx,
"position": 4,
}
)
2023-06-16 10:49:55 +03:00
if os.path.exists(crepe_onnx_full) is False:
downloadParams.append(
{
"url": "https://huggingface.co/wok000/weights/resolve/main/crepe/onnx/full.onnx",
"saveTo": crepe_onnx_full,
"position": 5,
}
)
if os.path.exists(crepe_onnx_tiny) is False:
downloadParams.append(
{
"url": "https://huggingface.co/wok000/weights/resolve/main/crepe/onnx/tiny.onnx",
"saveTo": crepe_onnx_tiny,
"position": 6,
}
)
2023-07-07 21:18:23 +03:00
if os.path.exists(content_vec_500_onnx) is False:
downloadParams.append(
{
"url": "https://huggingface.co/wok000/weights_gpl/resolve/main/content-vec/contentvec-f.onnx",
"saveTo": content_vec_500_onnx,
"position": 7,
}
)
2023-07-19 04:20:30 +03:00
if os.path.exists(rmvpe) is False:
2023-07-15 03:17:19 +03:00
downloadParams.append(
{
2023-10-09 08:24:56 +03:00
"url": "https://huggingface.co/wok000/weights/resolve/main/rmvpe/rmvpe_20231006.pt",
2023-07-15 03:17:19 +03:00
"saveTo": rmvpe,
"position": 8,
}
)
2023-08-26 07:48:03 +03:00
if os.path.exists(rmvpe_onnx) is False:
downloadParams.append(
{
2023-10-09 08:24:56 +03:00
"url": "https://huggingface.co/wok000/weights_gpl/resolve/main/rmvpe/rmvpe_20231006.onnx",
2023-08-26 07:48:03 +03:00
"saveTo": rmvpe_onnx,
"position": 9,
}
)
2023-07-15 03:17:19 +03:00
2023-06-16 10:49:55 +03:00
with ThreadPoolExecutor() as pool:
pool.map(download, downloadParams)
if os.path.exists(hubert_base) is False or os.path.exists(hubert_base_jp) is False or os.path.exists(hubert_soft) is False or os.path.exists(nsf_hifigan) is False or os.path.exists(nsf_hifigan_config) is False:
raise WeightDownladException()
2023-07-26 11:04:55 +03:00
# ファイルサイズをログに書き込む。(デバッグ用)
for weight in weight_files:
if os.path.exists(weight):
file_size = os.path.getsize(weight)
logger.debug(f"weight file [{weight}]: {file_size}")
2023-07-26 11:04:55 +03:00
else:
logger.warning(f"weight file is missing. {weight}")
2023-07-26 11:04:55 +03:00
raise WeightDownladException()