Text-to-Speech / app.py
zyingt's picture
Upload 685 files
0d80816
raw
history blame
1.97 kB
# Copyright (c) 2023 Amphion.
#
# This source code is licensed under the MIT license found in the
# LICENSE file in the root directory of this source tree.
import subprocess
command_to_run = "cd ./modules/monotonic_align;mkdir -p monotonic_align;python setup.py build_ext --inplace;cd /home/user/app"
try:
result = subprocess.check_output(command_to_run, shell=True, text=True)
print("Command output:")
print(result)
except subprocess.CalledProcessError as e:
print(f"Command failed with return code {e.returncode}")
import gradio as gr
import os
import inference
SUPPORTED_SPEAKERS = {
"92":"hifitts_92",
"6097":"hifitts_6097",
"6670":"hifitts_6670",
"6671":"hifitts_6671",
"8051":"hifitts_8051",
"9017":"hifitts_9017",
"9136":"hifitts_9136",
"11614":"hifitts_11614",
"11697":"hifitts_11697",
"12787":"hifitts_12787"
}
def tts_inference(
input_text,
target_speaker
):
args_list = ["--config", "./egs/tts/vits_hifitts/exp_config.json"]
args_list += ["--checkpoint_path", "./latest-checkpoint"]
args_list += ["--speaker_name", target_speaker]
args_list += ["--text", input_text]
args_list += ["--mode","single"]
args_list += ["--output_dir", "result"]
args_list += ["--log_level", "debug"]
os.environ["WORK_DIR"] = "./"
inference.main(args_list)
### Display ###
result_file = os.path.join(
"result/{}.wav".format(target_speaker)
)
return result_file
demo_inputs = [
gr.Textbox(
label="Input text",
type="text",
lines=1,
max_lines=20
),
gr.Radio(
choices=list(SUPPORTED_SPEAKERS.keys()),
label="Target Speaker",
value="92"
)
]
demo_output = gr.Audio(label="")
demo = gr.Interface(
fn=tts_inference,
inputs=demo_inputs,
outputs=demo_output,
title="Amphion HifiTTS Text-to-Speech Demo",
)
if __name__ == "__main__":
demo.launch(share=True)