forked from r9y9/ttslearn
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdemo_server.py
120 lines (99 loc) · 4.99 KB
/
demo_server.py
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
117
118
119
120
import argparse
import os
import tempfile
import numpy as np
import streamlit as st
import torch
import ttslearn
from scipy.io import wavfile
from stqdm import stqdm
from ttslearn.logger import getLogger
from ttslearn.pretrained import get_available_model_ids
def get_parser():
parser = argparse.ArgumentParser(description="TTS Demo with streamlit")
parser.add_argument(
"--device", type=str, default="cpu", help="Device (cpu or cuda)"
)
parser.add_argument("--verbose", type=int, default=1, help="Verbose level")
parser.add_argument("--model_ids", type=str, default=None, help="Path to model ids")
return parser
@st.cache
def create_tts_engine(model_id, device):
from ttslearn.pretrained import create_tts_engine
engine = create_tts_engine(model_id)
engine.set_device(device)
return engine
if __name__ == "__main__":
args = get_parser().parse_args()
logger = getLogger(verbose=args.verbose, add_stream_handler=False)
logger.info("Using device: {}".format(args.device))
st.title("Pythonで学ぶ音声合成のデモ")
on_streamlit_share = int(os.environ.get("ON_STREAMLIT_SHARE", 0))
if on_streamlit_share == 1:
extra_usage = """
注意事項:
サーバがダウンする現象を避けるために、提供する学習済みモデルの一部のみを左メニューに表示しています。
書籍中で解説したWaveNetとTacotron2は、処理速度が遅いため、除いていることに注意してください。
すべての学習済みモデルにアクセスするためには、ローカルでdemo_server.pyを実行してください。
"""
else:
extra_usage = ""
with st.expander("利用方法・規約を見る"):
st.text(
f"""
使い方:
1. 左メニューの Model ID から、学習済みモデルの名前を選択してください。
学習済みモデルの説明は、 https://r9y9.github.io/ttslearn/latest/pretrained.html を参照してください。
2. (Optional) 多話者音声合成の場合は、左メニューに、話者を選択するプルダウンメニューが表示されます。
好きな話者を選択してください。
3. 「日本語テキスト入力」から、合成したい日本語テキストを入力してください
4. 合成ボタンを押して下さい。
5. 音声を再生するボタンを押すと、合成音声が再生されます。
{extra_usage}
利用規約:
1. 公序良俗に反しない範囲で、「非商用目的」に限り、本デモページおよび合成された音声を無償で利用できます。
2. 本デモページによって合成された音声を公開・配布する場合は、本デモサイトを利用したことを明記してください。
3. 本デモページに入力されたテキストは、研究目的のためのサンプルデータとして利用されることがあります。但し、個人が特定されることはありません。
4. 作者は、本デモページの利用による一切の請求、損害、その他の義務について何らの責任も負わないものとします。
5. 本利用規約は、予告なく変更されることがあります。
ttslearn's version: {ttslearn.__version__}
"""
)
if args.model_ids is not None:
model_ids = []
with open(args.model_ids) as f:
for line in f:
s = line.strip()
if len(s) > 0:
model_ids.append(s)
elif os.environ.get("TTSLEARN_TTS_MODEL_IDS") is not None:
# This is mostly for streamlit share apps, where we have no control on app arguments
model_ids = os.environ.get("TTSLEARN_TTS_MODEL_IDS").split(",")
else:
model_ids = get_available_model_ids()
# 音声合成エンジンのインスタンス化
model_id = st.sidebar.selectbox("Model ID", model_ids)
engine = create_tts_engine(model_id, args.device)
# Multi-speaker TTSの場合、話者情報が必要
if hasattr(engine, "spks") and engine.spks is not None:
assert engine.spk2id is not None
spk = st.sidebar.selectbox("Speaker", engine.spks, index=0)
else:
spk = None
text = st.text_area("日本語テキスト入力", value="ここに、好きな日本語テキストを入力してください。").strip()
if st.button("合成") and len(text) > 0:
logger.info(f"Input text: {text}")
if spk is None:
wav, sr = engine.tts(text, tqdm=stqdm)
else:
logger.info(f"Speaker: {spk}")
wav, sr = engine.tts(text, tqdm=stqdm, spk_id=engine.spk2id[spk])
# 音量を正規化
assert wav.dtype == np.int16
wav = (wav / np.abs(wav).max() * 32767.0).astype(np.int16)
if torch.cuda.is_available():
torch.cuda.empty_cache()
with tempfile.NamedTemporaryFile(suffix=".wav") as f:
wavfile.write(f.name, sr, wav)
with open(f.name, "rb") as wav_file:
st.audio(wav_file.read(), format="audio/wav")