import gradio as gr import torch.cuda from InferenceInterfaces.ControllableInterface import ControllableInterface from Utility.utils import float2pcm class TTSWebUI: def __init__(self, gpu_id="cpu", title="Simplistic Stochastic Speech Synthesis with ToucanTTS", article="For a multilingual version, have a look at https://huggingface.co/spaces/Flux9665/MassivelyMultilingualTTS"): self.controllable_ui = ControllableInterface(gpu_id=gpu_id) self.iface = gr.Interface(fn=self.read, inputs=[gr.Textbox(lines=2, placeholder="write what you want the synthesis to read here...", value="What I cannot create, I do not understand.", label="Text input")], outputs=[gr.Audio(type="numpy", label="Speech")], title=title, theme="default", allow_flagging="never", article=article) self.iface.launch() def read(self, prompt): sr, wav = self.controllable_ui.read(prompt, -24.) return sr, float2pcm(wav) if __name__ == '__main__': TTSWebUI(gpu_id="cuda" if torch.cuda.is_available() else "cpu")