soujanyaporia commited on
Commit
86a3494
·
verified ·
1 Parent(s): 0b1b36b

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +11 -30
app.py CHANGED
@@ -53,13 +53,13 @@ class Tango:
53
  for i in range(0, len(lst), n):
54
  yield lst[i:i + n]
55
 
56
- def generate(self, prompt, steps=100, guidance=3, samples=3, disable_progress=True):
57
  """ Genrate audio for a single prompt string. """
58
  with torch.no_grad():
59
  latents = self.model.inference([prompt], self.scheduler, steps, guidance, samples, disable_progress=disable_progress)
60
  mel = self.vae.decode_first_stage(latents)
61
  wave = self.vae.decode_to_waveform(mel)
62
- return wave
63
 
64
  def generate_for_batch(self, prompts, steps=200, guidance=3, samples=1, batch_size=8, disable_progress=True):
65
  """ Genrate audio for a list of prompt strings. """
@@ -83,33 +83,18 @@ tango.vae.to(device_type)
83
  tango.stft.to(device_type)
84
  tango.model.to(device_type)
85
 
86
- @spaces.GPU(duration=120)
87
  def gradio_generate(prompt, output_format, steps, guidance):
88
  output_wave = tango.generate(prompt, steps, guidance)
89
- output_filename_1 = "tmp.wav"
90
- wavio.write(output_filename_1, output_wave[0], rate=16000, sampwidth=2)
91
- # output_wave = tango.generate_for_batch([prompt], steps, guidance, samples=3)
92
  # output_filename = f"{prompt.replace(' ', '_')}_{steps}_{guidance}"[:250] + ".wav"
93
-
94
- # output_filename_1 = "tmp1.wav"
95
- # wavio.write(output_filename_1, output_wave[0][0], rate=16000, sampwidth=2)
96
- # output_filename_2 = "tmp2.wav"
97
- # wavio.write(output_filename_2, output_wave[0][1], rate=16000, sampwidth=2)
98
- # output_filename_3 = "tmp3.wav"
99
- # wavio.write(output_filename_3, output_wave[0][2], rate=16000, sampwidth=2)
100
 
101
  if (output_format == "mp3"):
102
- AudioSegment.from_wav("tmp1.wav").export("tmp1.mp3", format = "mp3")
103
- output_filename_1 = "tmp1.mp3"
104
- # AudioSegment.from_wav("tmp1.wav").export("tmp1.mp3", format = "mp3")
105
- # output_filename_1 = "tmp1.mp3"
106
- # AudioSegment.from_wav("tmp2.wav").export("tmp2.mp3", format = "mp3")
107
- # output_filename_2 = "tmp2.mp3"
108
- # AudioSegment.from_wav("tmp3.wav").export("tmp3.mp3", format = "mp3")
109
- # output_filename_3 = "tmp3.mp3"
110
 
111
- # return [output_filename_1, output_filename_2, output_filename_3]
112
- return output_filename_1
113
 
114
  # description_text = """
115
  # <p><a href="https://huggingface.co/spaces/declare-lab/tango/blob/main/app.py?duplicate=true"> <img style="margin-top: 0em; margin-bottom: 0em" src="https://bit.ly/3gLdBN6" alt="Duplicate Space"></a> For faster inference without waiting in queue, you may duplicate the space and upgrade to a GPU in the settings. <br/><br/>
@@ -138,11 +123,8 @@ Generate audio using Tango2 by providing a text prompt. Tango2 was built from Ta
138
  """
139
  # Gradio input and output components
140
  input_text = gr.Textbox(lines=2, label="Prompt")
141
- output_format = gr.Radio(label = "Output format", info = "The file you can download", choices = ["mp3", "wav"], value = "wav")
142
- output_audio_1 = gr.Audio(label="Generated Audio", type="filepath")
143
- # output_audio_1 = gr.Audio(label="Generated Audio #1/3", type="filepath")
144
- # output_audio_2 = gr.Audio(label="Generated Audio #2/3", type="filepath")
145
- # output_audio_3 = gr.Audio(label="Generated Audio #3/3", type="filepath")
146
  denoising_steps = gr.Slider(minimum=100, maximum=200, value=100, step=1, label="Steps", interactive=True)
147
  guidance_scale = gr.Slider(minimum=1, maximum=10, value=3, step=0.1, label="Guidance Scale", interactive=True)
148
 
@@ -150,8 +132,7 @@ guidance_scale = gr.Slider(minimum=1, maximum=10, value=3, step=0.1, label="Guid
150
  gr_interface = gr.Interface(
151
  fn=gradio_generate,
152
  inputs=[input_text, output_format, denoising_steps, guidance_scale],
153
- outputs=[output_audio_1],
154
- # outputs=[output_audio_1, output_audio_2, output_audio_3],
155
  title="Tango 2: Aligning Diffusion-based Text-to-Audio Generations through Direct Preference Optimization",
156
  description=description_text,
157
  allow_flagging=False,
 
53
  for i in range(0, len(lst), n):
54
  yield lst[i:i + n]
55
 
56
+ def generate(self, prompt, steps=100, guidance=3, samples=1, disable_progress=True):
57
  """ Genrate audio for a single prompt string. """
58
  with torch.no_grad():
59
  latents = self.model.inference([prompt], self.scheduler, steps, guidance, samples, disable_progress=disable_progress)
60
  mel = self.vae.decode_first_stage(latents)
61
  wave = self.vae.decode_to_waveform(mel)
62
+ return wave[0]
63
 
64
  def generate_for_batch(self, prompts, steps=200, guidance=3, samples=1, batch_size=8, disable_progress=True):
65
  """ Genrate audio for a list of prompt strings. """
 
83
  tango.stft.to(device_type)
84
  tango.model.to(device_type)
85
 
86
+ @spaces.GPU(duration=60)
87
  def gradio_generate(prompt, output_format, steps, guidance):
88
  output_wave = tango.generate(prompt, steps, guidance)
 
 
 
89
  # output_filename = f"{prompt.replace(' ', '_')}_{steps}_{guidance}"[:250] + ".wav"
90
+ output_filename = "temp.wav"
91
+ wavio.write(output_filename, output_wave, rate=16000, sampwidth=2)
 
 
 
 
 
92
 
93
  if (output_format == "mp3"):
94
+ AudioSegment.from_wav("temp.wav").export("temp.mp3", format = "mp3")
95
+ output_filename = "temp.mp3"
 
 
 
 
 
 
96
 
97
+ return output_filename
 
98
 
99
  # description_text = """
100
  # <p><a href="https://huggingface.co/spaces/declare-lab/tango/blob/main/app.py?duplicate=true"> <img style="margin-top: 0em; margin-bottom: 0em" src="https://bit.ly/3gLdBN6" alt="Duplicate Space"></a> For faster inference without waiting in queue, you may duplicate the space and upgrade to a GPU in the settings. <br/><br/>
 
123
  """
124
  # Gradio input and output components
125
  input_text = gr.Textbox(lines=2, label="Prompt")
126
+ output_format = gr.Radio(label = "Output format", info = "The file you can dowload", choices = ["mp3", "wav"], value = "wav")
127
+ output_audio = gr.Audio(label="Generated Audio", type="filepath")
 
 
 
128
  denoising_steps = gr.Slider(minimum=100, maximum=200, value=100, step=1, label="Steps", interactive=True)
129
  guidance_scale = gr.Slider(minimum=1, maximum=10, value=3, step=0.1, label="Guidance Scale", interactive=True)
130
 
 
132
  gr_interface = gr.Interface(
133
  fn=gradio_generate,
134
  inputs=[input_text, output_format, denoising_steps, guidance_scale],
135
+ outputs=[output_audio],
 
136
  title="Tango 2: Aligning Diffusion-based Text-to-Audio Generations through Direct Preference Optimization",
137
  description=description_text,
138
  allow_flagging=False,