forked from jianchang512/ChatTTS-ui
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrun.py
73 lines (60 loc) · 2.2 KB
/
run.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
import os, sys
if sys.platform == "darwin":
os.environ["PYTORCH_ENABLE_MPS_FALLBACK"] = "1"
now_dir = os.getcwd()
sys.path.append(now_dir)
from dotenv import load_dotenv
load_dotenv("sha256.env")
import wave
import ChatTTS
from IPython.display import Audio
import numpy as np
def save_wav_file(wav, index):
wav_filename = f"output_audio_{index}.wav"
# Convert numpy array to bytes and write to WAV file
wav_bytes = (wav * 32768).astype('int16').tobytes()
with wave.open(wav_filename, "wb") as wf:
wf.setnchannels(1) # Mono channel
wf.setsampwidth(2) # Sample width in bytes
wf.setframerate(24000) # Sample rate in Hz
wf.writeframes(wav_bytes)
print(f"Audio saved to {wav_filename}")
def main():
# Retrieve text from command line argument
try:
sys.argv.remove('--stream')
stream = True
except:
stream = False
text_input = sys.argv[1] if len(sys.argv) > 1 else "<YOUR TEXT HERE>"
print("Received text input:", text_input)
chat = ChatTTS.Chat()
print("Initializing ChatTTS...")
# if using macbook(M1), I suggest you set `device='cpu', compile=False`
#chat.load_models()
chat.load_models(source="custom",custom_path='./models/pzc163/chattts')
print("Models loaded successfully.")
texts = [text_input]
print("Text prepared for inference:", texts)
wavs_gen = chat.infer(texts, use_decoder=True, stream=stream)
print("Inference completed. Audio generation successful.")
# Save each generated wav file to a local file
if stream:
print('generate with stream mode ..')
wavs = [np.array([[]])]
for gen in wavs_gen:
print('got new chunk', gen)
tmp=[np.array([[]])]
tmp[0]=np.hstack([tmp[0], np.array(gen[0])])
save_wav_file(tmp[0], 11)
wavs[0] = np.hstack([wavs[0], np.array(gen[0])])
else:
print('generate without stream mode ..')
wavs = wavs_gen
for index, wav in enumerate(wavs):
save_wav_file(wav, index)
return Audio(wavs[0], rate=24_000, autoplay=True)
if __name__ == "__main__":
print("Starting the TTS application...")
main()
print("TTS application finished.")