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
|
2023-07-26 22:06:25 +03:00
|
|
|
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
|
|
|
|
|
2023-07-26 22:06:25 +03:00
|
|
|
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
|
2023-07-06 20:17:29 +03:00
|
|
|
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
|
2024-02-28 17:08:49 +03:00
|
|
|
whisper_tiny = voiceChangerParams.whisper_tiny
|
2023-06-16 10:49:55 +03:00
|
|
|
|
2024-02-28 17:08:49 +03:00
|
|
|
weight_files = [
|
|
|
|
content_vec_500_onnx,
|
|
|
|
hubert_base,
|
|
|
|
hubert_base_jp,
|
|
|
|
hubert_soft,
|
|
|
|
nsf_hifigan,
|
|
|
|
crepe_onnx_full,
|
|
|
|
crepe_onnx_tiny,
|
|
|
|
rmvpe,
|
|
|
|
whisper_tiny,
|
|
|
|
]
|
2023-07-26 11:04:55 +03:00
|
|
|
|
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
|
|
|
|
2023-07-06 20:17:29 +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
|
|
|
|
2024-02-28 17:08:49 +03:00
|
|
|
if os.path.exists(whisper_tiny) is False:
|
|
|
|
downloadParams.append(
|
|
|
|
{
|
|
|
|
"url": "https://openaipublic.azureedge.net/main/whisper/models/65147644a518d12f04e32d6f3b26facc3f8dd46e5390956a9424a650c0ce22b9/tiny.pt",
|
|
|
|
"saveTo": whisper_tiny,
|
|
|
|
"position": 10,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
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)
|
2023-07-26 22:06:25 +03:00
|
|
|
logger.debug(f"weight file [{weight}]: {file_size}")
|
2023-07-26 11:04:55 +03:00
|
|
|
else:
|
2023-07-26 22:06:25 +03:00
|
|
|
logger.warning(f"weight file is missing. {weight}")
|
2023-07-26 11:04:55 +03:00
|
|
|
raise WeightDownladException()
|