|
import time |
|
|
|
import streamlit as st |
|
import numpy as np |
|
import torch |
|
from espnet2.bin.tts_inference import Text2Speech |
|
from scipy.io.wavfile import write |
|
from PIL import Image |
|
|
|
|
|
fs, lang = 44100, "Japanese" |
|
model= "./100epoch.pth" |
|
x = "これはテストメッセージです" |
|
|
|
text2speech = Text2Speech.from_pretrained( |
|
model_file=model, |
|
device="cpu", |
|
speed_control_alpha=1.0, |
|
noise_scale=0.333, |
|
noise_scale_dur=0.333, |
|
) |
|
pause = np.zeros(30000, dtype=np.float32) |
|
|
|
st.title("おしゃべりAI菅義偉メーカー") |
|
image = Image.open('suga.jpg') |
|
st.image(image) |
|
text = st.text_area(label='ここにテキストを入力 (Input Text)↓', height=100, max_chars=2048) |
|
|
|
|
|
if st.button("生成(Generate)"): |
|
with torch.no_grad(): |
|
wav = text2speech(text)["wav"] |
|
|
|
wav_list = [] |
|
wav_list.append(np.concatenate([wav.view(-1).cpu().numpy(), pause])) |
|
final_wav = np.concatenate(wav_list) |
|
st.audio(final_wav, sample_rate=fs) |
|
|