Spaces:
Running
Running
xJuuzouYTx
commited on
Commit
·
42cf67e
1
Parent(s):
66d588d
[ADD] error messages
Browse files- RVC_BOOK.ipynb +36 -0
- app.py +7 -0
- inference.py +6 -0
- utils/model.py +2 -17
RVC_BOOK.ipynb
ADDED
@@ -0,0 +1,36 @@
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
1 |
+
{
|
2 |
+
"cells": [
|
3 |
+
{
|
4 |
+
"cell_type": "markdown",
|
5 |
+
"metadata": {},
|
6 |
+
"source": [
|
7 |
+
"# <font color='#018ada'>ULTIVC Juuxn Version</font>\n",
|
8 |
+
"---\n",
|
9 |
+
"![youtube.png]() **[YouTube](https://www.youtube.com/@Juuxn)**\n",
|
10 |
+
"\n",
|
11 |
+
"**Enlaces que podrían interesarte:**\n",
|
12 |
+
"\n",
|
13 |
+
"- [Tutorial para este cuaderno](https://www.youtube.com/watch?v=gTWA2qyzX7k) - [Tutorial para cuaderno tradicional](https://www.youtube.com/embed/R8-PivPpv8o) - [Transferir archivo de mega a Drive](https://colab.research.google.com/drive/1utTesfmBv-uQ8Upa7TEVpM57kmcq9YN6?usp=sharing)\n",
|
14 |
+
"---"
|
15 |
+
]
|
16 |
+
},
|
17 |
+
{
|
18 |
+
"cell_type": "code",
|
19 |
+
"execution_count": null,
|
20 |
+
"metadata": {
|
21 |
+
"vscode": {
|
22 |
+
"languageId": "plaintext"
|
23 |
+
}
|
24 |
+
},
|
25 |
+
"outputs": [],
|
26 |
+
"source": []
|
27 |
+
}
|
28 |
+
],
|
29 |
+
"metadata": {
|
30 |
+
"language_info": {
|
31 |
+
"name": "python"
|
32 |
+
}
|
33 |
+
},
|
34 |
+
"nbformat": 4,
|
35 |
+
"nbformat_minor": 2
|
36 |
+
}
|
app.py
CHANGED
@@ -70,6 +70,13 @@ def infer(model, f0_method, audio_file):
|
|
70 |
def post_model(name, model_url, version, creator):
|
71 |
modelname = model_downloader(model_url, zips_folder, unzips_folder)
|
72 |
model_files = get_model(unzips_folder, modelname)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
73 |
md5_hash = calculate_md5(os.path.join(unzips_folder,model_files['pth']))
|
74 |
zipfile = compress(modelname, list(model_files.values()))
|
75 |
file_to_upload = open(zipfile, "rb")
|
|
|
70 |
def post_model(name, model_url, version, creator):
|
71 |
modelname = model_downloader(model_url, zips_folder, unzips_folder)
|
72 |
model_files = get_model(unzips_folder, modelname)
|
73 |
+
|
74 |
+
if not model_files:
|
75 |
+
return "No se encontrado un modelo valido, verifica el contenido del enlace e intentalo más tarde."
|
76 |
+
|
77 |
+
if not model_files.get('pth'):
|
78 |
+
return "No se encontrado un modelo valido, verifica el contenido del enlace e intentalo más tarde."
|
79 |
+
|
80 |
md5_hash = calculate_md5(os.path.join(unzips_folder,model_files['pth']))
|
81 |
zipfile = compress(modelname, list(model_files.values()))
|
82 |
file_to_upload = open(zipfile, "rb")
|
inference.py
CHANGED
@@ -198,6 +198,12 @@ class Inference:
|
|
198 |
modelname = model.model_downloader(self._model_name, "./zips/", "./weights/")
|
199 |
|
200 |
model_info = model.get_model(os.path.join(current_dir, 'weights') , modelname)
|
|
|
|
|
|
|
|
|
|
|
|
|
201 |
index = model_info.get('index', '')
|
202 |
pth = model_info.get('pth', None)
|
203 |
|
|
|
198 |
modelname = model.model_downloader(self._model_name, "./zips/", "./weights/")
|
199 |
|
200 |
model_info = model.get_model(os.path.join(current_dir, 'weights') , modelname)
|
201 |
+
if not model_info:
|
202 |
+
return "No se encontrado un modelo valido, verifica el contenido del enlace e intentalo más tarde."
|
203 |
+
|
204 |
+
if not model_info.get('pth'):
|
205 |
+
return "No se encontrado un modelo valido, verifica el contenido del enlace e intentalo más tarde."
|
206 |
+
|
207 |
index = model_info.get('index', '')
|
208 |
pth = model_info.get('pth', None)
|
209 |
|
utils/model.py
CHANGED
@@ -100,27 +100,12 @@ def model_downloader(url, zip_path, dest_path):
|
|
100 |
else:
|
101 |
return None
|
102 |
|
103 |
-
|
104 |
-
def get_models(weight_path):
|
105 |
-
# Obtener todos los elementos en la ruta
|
106 |
-
files = os.listdir(weight_path)
|
107 |
-
# Filtrar solo los directorios
|
108 |
-
return [file for file in files if os.path.isdir(os.path.join(weight_path, file))]
|
109 |
-
|
110 |
-
|
111 |
def get_model(weight_path, modelname):
|
112 |
resources = {}
|
113 |
for root, dirs, files in os.walk(os.path.join(weight_path, modelname)):
|
114 |
for file in files:
|
115 |
if file.endswith('.index'):
|
116 |
resources['index'] = os.path.relpath(os.path.join(root, file))
|
117 |
-
if file.endswith('.pth'):
|
118 |
resources['pth'] = os.path.relpath(os.path.join(root, file), start=weight_path)
|
119 |
-
return resources
|
120 |
-
|
121 |
-
|
122 |
-
def get_audios(audios_path):
|
123 |
-
# Obtener todos los elementos en la ruta
|
124 |
-
files = os.listdir(audios_path)
|
125 |
-
# Filtrar solo los directorios
|
126 |
-
return [file for file in files if not os.path.isdir(os.path.join(audios_path, file)) and os.path.join(audios_path, file).endswith(('.mp3', '.wav'))]
|
|
|
100 |
else:
|
101 |
return None
|
102 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
103 |
def get_model(weight_path, modelname):
|
104 |
resources = {}
|
105 |
for root, dirs, files in os.walk(os.path.join(weight_path, modelname)):
|
106 |
for file in files:
|
107 |
if file.endswith('.index'):
|
108 |
resources['index'] = os.path.relpath(os.path.join(root, file))
|
109 |
+
if file.endswith('.pth') and not 'G_' in file and not 'D_' in file:
|
110 |
resources['pth'] = os.path.relpath(os.path.join(root, file), start=weight_path)
|
111 |
+
return resources
|
|
|
|
|
|
|
|
|
|
|
|
|
|