Spaces:
Paused
Paused
import gradio as gr | |
lpmc_client = gr.load("seungheondoh/LP-Music-Caps-demo", src="spaces") | |
from gradio_client import Client | |
client = Client("https://ysharma-explore-llamav2-with-tgi.hf.space/") | |
sd = gr.load("runwayml/stable-diffusion-v1-5", src="spaces") | |
from pydub import AudioSegment | |
def cut_audio(input_path, output_path, max_duration=30000): | |
audio = AudioSegment.from_file(input_path) | |
if len(audio) > max_duration: | |
audio = audio[:max_duration] | |
audio.export(output_path, format="mp3") | |
return output_path | |
def infer(audio_file): | |
truncated_audio = cut_audio(audio_file, "trunc_audio.mp3") | |
cap_result = lpmc_client( | |
truncated_audio, # str (filepath or URL to file) in 'audio_path' Audio component | |
api_name="predict" | |
) | |
print(cap_result) | |
summarize_q = f""" | |
I'll give you a list of music descriptions. Create a summary reflecting the musical ambiance. | |
Do not processs each segment, but provide a summary for the whole instead. | |
Here's the list: | |
{cap_result} | |
""" | |
summary_result = client.predict( | |
summarize_q, # str in 'Message' Textbox component | |
api_name="/chat_1" | |
) | |
print(f"SUMMARY: {summary_result}") | |
llama_q = f""" | |
I'll give you music description, then i want you to provide an illustrative image description that would fit well with the music. | |
Answer with only one image description. Never do lists. | |
Here's the music description : | |
{summary_result} | |
""" | |
result = client.predict( | |
llama_q, # str in 'Message' Textbox component | |
api_name="/chat_1" | |
) | |
print(result) | |
image = sd(result, fn_index=0)[0] | |
return cap_result, result, image | |
with gr.Blocks() as demo: | |
with gr.Column(elem_id="col-container"): | |
audio_input = gr.Audio(type="filepath", source="upload") | |
infer_btn = gr.Button("Generate") | |
lpmc_cap = gr.Textbox(label="Lp Music Caps caption") | |
llama_trans_cap = gr.Textbox(label="Llama translation") | |
img_result = gr.Video(label="Result") | |
infer_btn.click(fn=infer, inputs=[audio_input], outputs=[lpmc_cap, llama_trans_cap, img_result]) | |
demo.queue().launch() |