Spaces:
Runtime error
Runtime error
File size: 5,459 Bytes
408ebe4 01a69aa 408ebe4 01a69aa 408ebe4 01a69aa 408ebe4 01a69aa 408ebe4 01a69aa 408ebe4 01a69aa 408ebe4 01a69aa 408ebe4 01a69aa 408ebe4 01a69aa 408ebe4 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 |
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)
@gr.render(inputs=[auto_play_checkbox, stream_mode_checkbox])
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()
|