Voice.clone / app.py
deekshachilukuri's picture
Update app.py
979c564 verified
raw
history blame
1.21 kB
import torch
import gradio as gr
from TTS.api import TTS
import os
from unittest.mock import patch
os.environ["COQUI_TOS_AGREED"] = "1"
# Function to always return 'y'
def always_yes(*args, **kwargs):
return 'y'
# Patch the input function to always return 'y'
with patch('builtins.input', always_yes):
device = "cuda:0" if torch.cuda.is_available() else "cpu"
tts = TTS(model_name="tts_models/multilingual/multi-dataset/xtts_v2", progress_bar=False).to(device)
def generate_voice(text, audio_file_path):
output_path = "/content/cloned_audio.wav" # Setting the output path
tts.tts_to_file(text,
speaker_wav=audio_file_path, # Directly use the file path string
language="en", # Assuming the language is English
file_path=output_path,
split_sentences=True)
return output_path
import gradio as gr
# Define the Gradio interface
iface = gr.Interface(
fn=generate_voice,
inputs=[
gr.Textbox(label="Input Text"),
gr.Audio(label="Input Audio", type="filepath")
],
outputs=gr.Audio(label="Cloned Voice"),
title="Voice Cloning TTS"
)
# Launch the interface
iface.launch()