ArkanDash commited on
Commit
f263171
·
1 Parent(s): eee9bac

test: load duplicate bug

Browse files
Files changed (2) hide show
  1. app.py +59 -4
  2. config.py +3 -3
app.py CHANGED
@@ -132,6 +132,9 @@ def create_vc_fn(model_name, tgt_sr, net_g, vc, if_f0, version, file_index):
132
  def load_model():
133
  categories = []
134
  if os.path.isfile("weights/folder_info.json"):
 
 
 
135
  with open("weights/folder_info.json", "r", encoding="utf-8") as f:
136
  folder_info = json.load(f)
137
  for category_name, category_info in folder_info.items():
@@ -140,7 +143,11 @@ def load_model():
140
  category_title = category_info['title']
141
  category_folder = category_info['folder_path']
142
  description = category_info['description']
 
143
  models = []
 
 
 
144
  with open(f"weights/{category_folder}/model_info.json", "r", encoding="utf-8") as f:
145
  models_info = json.load(f)
146
  for character_name, info in models_info.items():
@@ -176,9 +183,57 @@ def load_model():
176
  else:
177
  net_g = net_g.float()
178
  vc = VC(tgt_sr, config)
179
- print(f"Model loaded: {character_name} / {info['feature_retrieval_library']} | ({model_version})")
 
180
  models.append((character_name, model_title, model_author, model_cover, model_version, create_vc_fn(model_name, tgt_sr, net_g, vc, if_f0, version, model_index)))
181
- categories.append([category_title, category_folder, description, models])
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
182
  else:
183
  categories = []
184
  return categories
@@ -386,7 +441,7 @@ if __name__ == '__main__':
386
  "## No model found, please add the model into weights folder\n\n"+
387
  "</div>"
388
  )
389
- for (folder_title, folder, description, models) in categories:
390
  with gr.TabItem(folder_title):
391
  if description:
392
  gr.Markdown(f"### <center> {description}")
@@ -676,4 +731,4 @@ if __name__ == '__main__':
676
  tts_voice
677
  ]
678
  )
679
- app.queue(concurrency_count=5, max_size=50, api_open=config.api).launch(share=config.colab)
 
132
  def load_model():
133
  categories = []
134
  if os.path.isfile("weights/folder_info.json"):
135
+ for _, w_dirs, _ in os.walk(f"weights"):
136
+ category_count_total = len(w_dirs)
137
+ category_count = 1
138
  with open("weights/folder_info.json", "r", encoding="utf-8") as f:
139
  folder_info = json.load(f)
140
  for category_name, category_info in folder_info.items():
 
143
  category_title = category_info['title']
144
  category_folder = category_info['folder_path']
145
  description = category_info['description']
146
+ print(f"Load {category_title} [{category_count}/{category_count_total}]")
147
  models = []
148
+ for _, m_dirs, _ in os.walk(f"weights/{category_folder}"):
149
+ model_count_total = len(m_dirs)
150
+ model_count = 1
151
  with open(f"weights/{category_folder}/model_info.json", "r", encoding="utf-8") as f:
152
  models_info = json.load(f)
153
  for character_name, info in models_info.items():
 
183
  else:
184
  net_g = net_g.float()
185
  vc = VC(tgt_sr, config)
186
+ print(f"Model loaded [{model_count}/{model_count_total}]: {character_name} / {info['feature_retrieval_library']} | ({model_version})")
187
+ model_count += 1
188
  models.append((character_name, model_title, model_author, model_cover, model_version, create_vc_fn(model_name, tgt_sr, net_g, vc, if_f0, version, model_index)))
189
+ category_count += 1
190
+ categories.append([category_title, description, models])
191
+ elif os.path.exists("weights"):
192
+ models = []
193
+ for w_root, w_dirs, _ in os.walk("weights"):
194
+ model_count = 1
195
+ for sub_dir in w_dirs:
196
+ pth_files = glob.glob(f"weights/{sub_dir}/*.pth")
197
+ index_files = glob.glob(f"weights/{sub_dir}/*.index")
198
+ if pth_files == []:
199
+ print(f"Model [{model_count}/{len(w_dirs)}]: No Model file detected, skipping...")
200
+ continue
201
+ cpt = torch.load(pth_files[0])
202
+ tgt_sr = cpt["config"][-1]
203
+ cpt["config"][-3] = cpt["weight"]["emb_g.weight"].shape[0] # n_spk
204
+ if_f0 = cpt.get("f0", 1)
205
+ version = cpt.get("version", "v1")
206
+ if version == "v1":
207
+ if if_f0 == 1:
208
+ net_g = SynthesizerTrnMs256NSFsid(*cpt["config"], is_half=config.is_half)
209
+ else:
210
+ net_g = SynthesizerTrnMs256NSFsid_nono(*cpt["config"])
211
+ model_version = "V1"
212
+ elif version == "v2":
213
+ if if_f0 == 1:
214
+ net_g = SynthesizerTrnMs768NSFsid(*cpt["config"], is_half=config.is_half)
215
+ else:
216
+ net_g = SynthesizerTrnMs768NSFsid_nono(*cpt["config"])
217
+ model_version = "V2"
218
+ del net_g.enc_q
219
+ print(net_g.load_state_dict(cpt["weight"], strict=False))
220
+ net_g.eval().to(config.device)
221
+ if config.is_half:
222
+ net_g = net_g.half()
223
+ else:
224
+ net_g = net_g.float()
225
+ vc = VC(tgt_sr, config)
226
+ if index_files == []:
227
+ print("Warning: No Index file detected!")
228
+ index_info = "None"
229
+ model_index = ""
230
+ else:
231
+ index_info = index_files[0]
232
+ model_index = index_files[0]
233
+ print(f"Model loaded [{model_count}/{len(w_dirs)}]: {index_files[0]} / {index_info} | ({model_version})")
234
+ model_count += 1
235
+ models.append((index_files[0][:-4], index_files[0][:-4], "", "", model_version, create_vc_fn(index_files[0], tgt_sr, net_g, vc, if_f0, version, model_index)))
236
+ categories.append(["Models", "", models])
237
  else:
238
  categories = []
239
  return categories
 
441
  "## No model found, please add the model into weights folder\n\n"+
442
  "</div>"
443
  )
444
+ for (folder_title, description, models) in categories:
445
  with gr.TabItem(folder_title):
446
  if description:
447
  gr.Markdown(f"### <center> {description}")
 
731
  tts_voice
732
  ]
733
  )
734
+ app.queue(concurrency_count=5, max_size=50, api_open=config.api).launch(share=config.share)
config.py CHANGED
@@ -11,7 +11,7 @@ class Config:
11
  self.gpu_name = None
12
  self.gpu_mem = None
13
  (
14
- self.colab,
15
  self.api,
16
  self.unsupported
17
  ) = self.arg_parse()
@@ -20,13 +20,13 @@ class Config:
20
  @staticmethod
21
  def arg_parse() -> tuple:
22
  parser = argparse.ArgumentParser()
23
- parser.add_argument("--colab", action="store_true", help="Launch in colab")
24
  parser.add_argument("--api", action="store_true", help="Launch with api")
25
  parser.add_argument("--unsupported", action="store_true", help="Enable unsupported feature")
26
  cmd_opts = parser.parse_args()
27
 
28
  return (
29
- cmd_opts.colab,
30
  cmd_opts.api,
31
  cmd_opts.unsupported
32
  )
 
11
  self.gpu_name = None
12
  self.gpu_mem = None
13
  (
14
+ self.share,
15
  self.api,
16
  self.unsupported
17
  ) = self.arg_parse()
 
20
  @staticmethod
21
  def arg_parse() -> tuple:
22
  parser = argparse.ArgumentParser()
23
+ parser.add_argument("--share", action="store_true", help="Launch with public link")
24
  parser.add_argument("--api", action="store_true", help="Launch with api")
25
  parser.add_argument("--unsupported", action="store_true", help="Enable unsupported feature")
26
  cmd_opts = parser.parse_args()
27
 
28
  return (
29
+ cmd_opts.share,
30
  cmd_opts.api,
31
  cmd_opts.unsupported
32
  )