Spaces:
Runtime error
Runtime error
import os, sys | |
if sys.platform == "darwin": | |
os.environ["PYTORCH_ENABLE_MPS_FALLBACK"] = "1" | |
now_dir = os.getcwd() | |
sys.path.append(now_dir) | |
import argparse | |
import gradio as gr | |
from dotenv import load_dotenv | |
load_dotenv("sha256.env") | |
from examples.web.funcs import * | |
def main(): | |
with gr.Blocks() as demo: | |
gr.Markdown("# ChatTTS WebUI") | |
gr.Markdown("- **GitHub Repo**: https://github.com/2noise/ChatTTS") | |
gr.Markdown("- **HuggingFace Repo**: https://huggingface.co/2Noise/ChatTTS") | |
default_text = "四川美食确实以辣闻名,但也有不辣的选择。比如甜水面、赖汤圆、蛋烘糕、叶儿粑等,这些小吃口味温和,甜而不腻,也很受欢迎。" | |
text_input = gr.Textbox(label="Input Text", lines=4, placeholder="Please Input Text...", value=default_text) | |
with gr.Row(): | |
refine_text_checkbox = gr.Checkbox(label="Refine text", value=True) | |
temperature_slider = gr.Slider(minimum=0.00001, maximum=1.0, step=0.00001, value=0.3, label="Audio temperature", interactive=True) | |
top_p_slider = gr.Slider(minimum=0.1, maximum=0.9, step=0.05, value=0.7, label="top_P", interactive=True) | |
top_k_slider = gr.Slider(minimum=1, maximum=20, step=1, value=20, label="top_K", interactive=True) | |
with gr.Row(): | |
voice_selection = gr.Dropdown(label="音色", choices=voices.keys(), value='默认') | |
audio_seed_input = gr.Number(value=2, label="Audio Seed") | |
generate_audio_seed = gr.Button("\U0001F3B2") | |
text_seed_input = gr.Number(value=42, label="Text Seed") | |
generate_text_seed = gr.Button("\U0001F3B2") | |
with gr.Row(): | |
auto_play_checkbox = gr.Checkbox(label="Auto Play", value=False, scale=1) | |
stream_mode_checkbox = gr.Checkbox(label="Stream Mode", value=False, scale=1) | |
generate_button = gr.Button("Generate", scale=2) | |
text_output = gr.Textbox(label="Output Text", interactive=False) | |
# 使用Gradio的回调功能来更新数值输入框 | |
voice_selection.change(fn=on_voice_change, inputs=voice_selection, outputs=audio_seed_input) | |
generate_audio_seed.click(generate_seed, | |
inputs=[], | |
outputs=audio_seed_input) | |
generate_text_seed.click(generate_seed, | |
inputs=[], | |
outputs=text_seed_input) | |
generate_button.click(fn=lambda: "", outputs=text_output) | |
generate_button.click(refine_text, | |
inputs=[text_input, audio_seed_input, text_seed_input, refine_text_checkbox], | |
outputs=text_output) | |
def make_audio(autoplay, stream): | |
audio_output = gr.Audio( | |
label="Output Audio", | |
value=None, | |
autoplay=autoplay, | |
streaming=stream, | |
interactive=False, | |
show_label=True, | |
) | |
text_output.change(generate_audio, | |
inputs=[text_output, temperature_slider, top_p_slider, top_k_slider, audio_seed_input, text_seed_input, stream_mode_checkbox], | |
outputs=audio_output) | |
gr.Examples( | |
examples=[ | |
["四川美食确实以辣闻名,但也有不辣的选择。比如甜水面、赖汤圆、蛋烘糕、叶儿粑等,这些小吃口味温和,甜而不腻,也很受欢迎。", 0.3, 0.7, 20, 2, 42, True], | |
["What is [uv_break]your favorite english food?[laugh][lbreak]", 0.5, 0.5, 10, 245, 531, True], | |
["chat T T S is a text to speech model designed for dialogue applications. [uv_break]it supports mixed language input [uv_break]and offers multi speaker capabilities with precise control over prosodic elements [laugh]like like [uv_break]laughter[laugh], [uv_break]pauses, [uv_break]and intonation. [uv_break]it delivers natural and expressive speech,[uv_break]so please[uv_break] use the project responsibly at your own risk.[uv_break]", 0.2, 0.6, 15, 67, 165, True], | |
], | |
inputs=[text_input, temperature_slider, top_p_slider, top_k_slider, audio_seed_input, text_seed_input, refine_text_checkbox], | |
) | |
parser = argparse.ArgumentParser(description='ChatTTS demo Launch') | |
parser.add_argument('--server_name', type=str, default='0.0.0.0', help='Server name') | |
parser.add_argument('--server_port', type=int, default=8080, help='Server port') | |
parser.add_argument('--root_path', type=str, default=None, help='Root Path') | |
parser.add_argument('--custom_path', type=str, default=None, help='the custom model path') | |
args = parser.parse_args() | |
logger.info("loading ChatTTS model...") | |
global chat | |
if args.custom_path == None: | |
ret = chat.load_models() | |
else: | |
logger.info('local model path: %s', args.custom_path) | |
ret = chat.load_models('custom', custom_path=args.custom_path) | |
if ret: | |
logger.info("Models loaded successfully.") | |
else: | |
logger.error("Models load failed.") | |
sys.exit(1) | |
demo.launch(server_name=args.server_name, server_port=args.server_port, root_path=args.root_path, inbrowser=True) | |
if __name__ == '__main__': | |
main() | |