import torch import gradio as gr from audiocraft.models import musicgen from audiocraft.utils.notebook import display_audio gcPU = torch.device('cuda' if torch.cuda.is_available() else 'cpu') audiocraft__music_gen__large = musicgen.MusicGen.get_pretrained('facebook/musicgen-medium', device=gcPU) audiocraft__music_gen__large.set_generation_params(duration=15) # for sample_rate=24KHz to get actual duration of 20sec def func__genA(ip): print('[p] :: ... processing ...') print(f"[logs] :: processing on '{gcPU}' device") try: op = audiocraft__music_gen__large.generate(ip,progress=True) return 'genA',(24000,op) # 1sec=32KHz(here-audiocraft) i.e to get the audio in the specified duration, initialize sample_rate=32000 except Exception as expn: return expn,gr.Audio() with gr.Blocks() as io: gr.Markdown('