Spaces:
Building
on
L40S
Building
on
L40S
Update app.py
Browse files
app.py
CHANGED
@@ -20,7 +20,6 @@ logging.basicConfig(
|
|
20 |
]
|
21 |
)
|
22 |
|
23 |
-
|
24 |
# κ°μ¬ λΆμ ν¨μ
|
25 |
def analyze_lyrics(lyrics):
|
26 |
# μ€ λ¨μλ‘ λΆλ¦¬
|
@@ -162,7 +161,6 @@ def install_flash_attn():
|
|
162 |
except ImportError:
|
163 |
logging.info("Installing flash-attn...")
|
164 |
|
165 |
-
# CUDA 12.1μ© μ§μ μ€μΉ μλ
|
166 |
try:
|
167 |
subprocess.run(
|
168 |
["pip", "install", "flash-attn", "--no-build-isolation"],
|
@@ -179,18 +177,6 @@ def install_flash_attn():
|
|
179 |
logging.warning(f"Failed to install flash-attn: {e}")
|
180 |
return False
|
181 |
|
182 |
-
# ... (λλ¨Έμ§ μ½λλ λμΌ) ...
|
183 |
-
|
184 |
-
# μλ² μ€μ μΌλ‘ μ€ν λΆλΆλ§ μμ
|
185 |
-
demo.queue(max_size=20).launch(
|
186 |
-
server_name="0.0.0.0",
|
187 |
-
server_port=7860,
|
188 |
-
share=True,
|
189 |
-
show_api=True,
|
190 |
-
show_error=True,
|
191 |
-
max_threads=2 # concurrency_count λμ max_threads μ¬μ©
|
192 |
-
)
|
193 |
-
|
194 |
def initialize_system():
|
195 |
optimize_gpu_settings()
|
196 |
has_flash_attn = install_flash_attn()
|
@@ -214,6 +200,38 @@ def initialize_system():
|
|
214 |
logging.error(f"Directory error: {e}")
|
215 |
raise
|
216 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
217 |
def infer(genre_txt_content, lyrics_txt_content, num_segments, max_new_tokens):
|
218 |
try:
|
219 |
# λͺ¨λΈ μ ν λ° μ€μ
|
@@ -299,130 +317,109 @@ def infer(genre_txt_content, lyrics_txt_content, num_segments, max_new_tokens):
|
|
299 |
except Exception as e:
|
300 |
logging.warning(f"Failed to remove temporary file {file}: {e}")
|
301 |
|
302 |
-
|
303 |
-
|
304 |
-
|
305 |
-
|
306 |
-
|
307 |
-
|
308 |
-
|
309 |
-
|
310 |
-
|
311 |
-
|
312 |
-
|
313 |
-
|
314 |
-
|
315 |
-
|
316 |
-
|
317 |
-
|
318 |
-
|
319 |
-
|
320 |
-
|
321 |
-
|
322 |
-
|
323 |
-
|
324 |
-
|
325 |
-
|
326 |
-
|
327 |
-
|
328 |
-
|
329 |
-
|
330 |
-
|
331 |
-
|
332 |
-
|
333 |
-
|
334 |
-
|
335 |
-
|
336 |
-
|
337 |
-
|
338 |
-
|
339 |
-
|
340 |
-
|
341 |
-
|
342 |
-
|
343 |
-
|
344 |
-
|
345 |
-
|
346 |
-
|
347 |
-
|
348 |
-
label="
|
349 |
-
|
350 |
-
|
351 |
-
|
352 |
-
|
353 |
-
|
354 |
-
|
355 |
-
|
356 |
-
|
357 |
-
|
358 |
-
|
359 |
-
|
360 |
-
|
361 |
-
|
362 |
-
|
363 |
-
|
364 |
-
|
365 |
-
|
366 |
-
|
367 |
-
|
368 |
-
|
369 |
-
|
370 |
-
|
371 |
-
|
372 |
-
|
373 |
-
|
374 |
-
|
375 |
-
|
376 |
-
|
377 |
-
|
378 |
-
|
379 |
-
|
380 |
-
|
381 |
-
|
382 |
-
|
383 |
-
|
384 |
-
|
385 |
-
|
386 |
-
|
387 |
-
With you here beside me, everything's alright
|
388 |
-
Can't imagine life alone, don't want to let you go
|
389 |
-
Stay with me forever, let our love just flow
|
390 |
-
|
391 |
-
"""
|
392 |
],
|
393 |
-
|
394 |
-
|
395 |
-
"K-pop bright energetic synth dance electronic",
|
396 |
-
"""[verse]
|
397 |
-
λΉλλ λ³λ€μ²λΌ μ°λ¦¬μ κΏμ΄
|
398 |
-
μ νλμ μλμ λ°μ§μ΄λ€
|
399 |
-
ν¨κ»λΌλ©΄ μ΄λλ κ° μ μμ΄
|
400 |
-
μ°λ¦¬μ μ΄μΌκΈ°κ° μμλλ€
|
401 |
-
|
402 |
-
[chorus]
|
403 |
-
λ¬λ €κ°μ λ λμ΄ λ λ©λ¦¬
|
404 |
-
λλ €μμ μμ΄ λμ ν¨κ»λΌλ©΄
|
405 |
-
μμν κ³μλ μ°λ¦¬μ λ
Έλ
|
406 |
-
μ΄ μκ°μ κΈ°μ΅ν΄ forever
|
407 |
|
408 |
-
|
409 |
-
|
410 |
-
|
411 |
-
|
|
|
|
|
|
|
|
|
412 |
)
|
413 |
|
414 |
-
|
415 |
-
initialize_system()
|
416 |
-
|
417 |
-
# μ΄λ²€νΈ νΈλ€λ¬
|
418 |
-
submit_btn.click(
|
419 |
-
fn=infer,
|
420 |
-
inputs=[genre_txt, lyrics_txt, num_segments, max_new_tokens],
|
421 |
-
outputs=[music_out]
|
422 |
-
)
|
423 |
|
424 |
-
# μλ² μ€μ μΌλ‘ μ€ν
|
425 |
if __name__ == "__main__":
|
|
|
426 |
demo.queue(max_size=20).launch(
|
427 |
server_name="0.0.0.0",
|
428 |
server_port=7860,
|
|
|
20 |
]
|
21 |
)
|
22 |
|
|
|
23 |
# κ°μ¬ λΆμ ν¨μ
|
24 |
def analyze_lyrics(lyrics):
|
25 |
# μ€ λ¨μλ‘ λΆλ¦¬
|
|
|
161 |
except ImportError:
|
162 |
logging.info("Installing flash-attn...")
|
163 |
|
|
|
164 |
try:
|
165 |
subprocess.run(
|
166 |
["pip", "install", "flash-attn", "--no-build-isolation"],
|
|
|
177 |
logging.warning(f"Failed to install flash-attn: {e}")
|
178 |
return False
|
179 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
180 |
def initialize_system():
|
181 |
optimize_gpu_settings()
|
182 |
has_flash_attn = install_flash_attn()
|
|
|
200 |
logging.error(f"Directory error: {e}")
|
201 |
raise
|
202 |
|
203 |
+
@lru_cache(maxsize=100)
|
204 |
+
def get_cached_file_path(content_hash, prefix):
|
205 |
+
return create_temp_file(content_hash, prefix)
|
206 |
+
|
207 |
+
def empty_output_folder(output_dir):
|
208 |
+
try:
|
209 |
+
shutil.rmtree(output_dir)
|
210 |
+
os.makedirs(output_dir)
|
211 |
+
logging.info(f"Output folder cleaned: {output_dir}")
|
212 |
+
except Exception as e:
|
213 |
+
logging.error(f"Error cleaning output folder: {e}")
|
214 |
+
raise
|
215 |
+
|
216 |
+
def create_temp_file(content, prefix, suffix=".txt"):
|
217 |
+
temp_file = tempfile.NamedTemporaryFile(delete=False, mode="w", prefix=prefix, suffix=suffix)
|
218 |
+
content = content.strip() + "\n\n"
|
219 |
+
content = content.replace("\r\n", "\n").replace("\r", "\n")
|
220 |
+
temp_file.write(content)
|
221 |
+
temp_file.close()
|
222 |
+
logging.debug(f"Temporary file created: {temp_file.name}")
|
223 |
+
return temp_file.name
|
224 |
+
|
225 |
+
def get_last_mp3_file(output_dir):
|
226 |
+
mp3_files = [f for f in os.listdir(output_dir) if f.endswith('.mp3')]
|
227 |
+
if not mp3_files:
|
228 |
+
logging.warning("No MP3 files found")
|
229 |
+
return None
|
230 |
+
|
231 |
+
mp3_files_with_path = [os.path.join(output_dir, f) for f in mp3_files]
|
232 |
+
mp3_files_with_path.sort(key=os.path.getmtime, reverse=True)
|
233 |
+
return mp3_files_with_path[0]
|
234 |
+
|
235 |
def infer(genre_txt_content, lyrics_txt_content, num_segments, max_new_tokens):
|
236 |
try:
|
237 |
# λͺ¨λΈ μ ν λ° μ€μ
|
|
|
317 |
except Exception as e:
|
318 |
logging.warning(f"Failed to remove temporary file {file}: {e}")
|
319 |
|
320 |
+
def main():
|
321 |
+
# Gradio μΈν°νμ΄μ€
|
322 |
+
with gr.Blocks() as demo:
|
323 |
+
with gr.Column():
|
324 |
+
gr.Markdown("# YuE: Open Music Foundation Models for Full-Song Generation (Multi-Language Support)")
|
325 |
+
gr.HTML("""
|
326 |
+
<div style="display:flex;column-gap:4px;">
|
327 |
+
<a href="https://github.com/multimodal-art-projection/YuE">
|
328 |
+
<img src='https://img.shields.io/badge/GitHub-Repo-blue'>
|
329 |
+
</a>
|
330 |
+
<a href="https://map-yue.github.io">
|
331 |
+
<img src='https://img.shields.io/badge/Project-Page-green'>
|
332 |
+
</a>
|
333 |
+
</div>
|
334 |
+
""")
|
335 |
+
|
336 |
+
with gr.Row():
|
337 |
+
with gr.Column():
|
338 |
+
genre_txt = gr.Textbox(
|
339 |
+
label="Genre",
|
340 |
+
placeholder="Enter music genre and style descriptions..."
|
341 |
+
)
|
342 |
+
lyrics_txt = gr.Textbox(
|
343 |
+
label="Lyrics (Supports English, Korean, Japanese, Chinese)",
|
344 |
+
placeholder="Enter song lyrics with [verse], [chorus], [bridge] tags...",
|
345 |
+
lines=10
|
346 |
+
)
|
347 |
+
|
348 |
+
with gr.Column():
|
349 |
+
num_segments = gr.Number(
|
350 |
+
label="Number of Song Segments (Auto-adjusted based on lyrics)",
|
351 |
+
value=2,
|
352 |
+
minimum=1,
|
353 |
+
maximum=4,
|
354 |
+
step=1,
|
355 |
+
interactive=False
|
356 |
+
)
|
357 |
+
max_new_tokens = gr.Slider(
|
358 |
+
label="Max New Tokens (Auto-adjusted based on lyrics)",
|
359 |
+
minimum=500,
|
360 |
+
maximum=32000,
|
361 |
+
step=500,
|
362 |
+
value=4000,
|
363 |
+
interactive=False
|
364 |
+
)
|
365 |
+
submit_btn = gr.Button("Generate Music", variant="primary")
|
366 |
+
music_out = gr.Audio(label="Generated Audio")
|
367 |
+
|
368 |
+
# λ€κ΅μ΄ μμ
|
369 |
+
gr.Examples(
|
370 |
+
examples=[
|
371 |
+
# μμ΄ μμ
|
372 |
+
[
|
373 |
+
"female blues airy vocal bright vocal piano sad romantic guitar jazz",
|
374 |
+
"""[verse]
|
375 |
+
In the quiet of the evening, shadows start to fall
|
376 |
+
Whispers of the night wind echo through the hall
|
377 |
+
Lost within the silence, I hear your gentle voice
|
378 |
+
Guiding me back homeward, making my heart rejoice
|
379 |
+
|
380 |
+
[chorus]
|
381 |
+
Don't let this moment fade, hold me close tonight
|
382 |
+
With you here beside me, everything's alright
|
383 |
+
Can't imagine life alone, don't want to let you go
|
384 |
+
Stay with me forever, let our love just flow
|
385 |
+
|
386 |
+
"""
|
387 |
+
],
|
388 |
+
# νκ΅μ΄ μμ
|
389 |
+
[
|
390 |
+
"K-pop bright energetic synth dance electronic",
|
391 |
+
"""[verse]
|
392 |
+
λΉλλ λ³λ€μ²λΌ μ°λ¦¬μ κΏμ΄
|
393 |
+
μ νλμ μλμ λ°μ§μ΄λ€
|
394 |
+
ν¨κ»λΌλ©΄ μ΄λλ κ° μ μμ΄
|
395 |
+
μ°λ¦¬μ μ΄μΌκΈ°κ° μμλλ€
|
396 |
+
|
397 |
+
[chorus]
|
398 |
+
λ¬λ €κ°μ λ λμ΄ λ λ©λ¦¬
|
399 |
+
λλ €μμ μμ΄ λμ ν¨κ»λΌλ©΄
|
400 |
+
μμν κ³μλ μ°λ¦¬μ λ
Έλ
|
401 |
+
μ΄ μκ°μ κΈ°μ΅ν΄ forever
|
402 |
+
|
403 |
+
"""
|
404 |
+
]
|
|
|
|
|
|
|
|
|
|
|
405 |
],
|
406 |
+
inputs=[genre_txt, lyrics_txt]
|
407 |
+
)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
408 |
|
409 |
+
# μμ€ν
μ΄κΈ°ν
|
410 |
+
initialize_system()
|
411 |
+
|
412 |
+
# μ΄λ²€νΈ νΈλ€λ¬
|
413 |
+
submit_btn.click(
|
414 |
+
fn=infer,
|
415 |
+
inputs=[genre_txt, lyrics_txt, num_segments, max_new_tokens],
|
416 |
+
outputs=[music_out]
|
417 |
)
|
418 |
|
419 |
+
return demo
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
420 |
|
|
|
421 |
if __name__ == "__main__":
|
422 |
+
demo = main()
|
423 |
demo.queue(max_size=20).launch(
|
424 |
server_name="0.0.0.0",
|
425 |
server_port=7860,
|