forked from yynil/RWKVTTS
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_initialize.py
58 lines (52 loc) · 2.82 KB
/
test_initialize.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
import time
def do_tts(tts_text,prompt_texts,cosyvoice,prefix):
import logging
for i, (prompt_audio_file, prompt_text) in enumerate(zip(prompt_audios, prompt_texts)):
logging.info(f'Processing {prompt_text}')
prompt_speech_16k = load_wav(prompt_audio_file, 16000)
with torch.no_grad():
if prompt_text is not None:
for j, k in enumerate(cosyvoice.inference_zero_shot(tts_text,prompt_text, prompt_speech_16k, stream=False,speed=1)):
torch.cuda.manual_seed_all(time.time())
torchaudio.save('{}_{}_{}.wav'.format(prefix,i, j), k['tts_speech'], cosyvoice.sample_rate)
else:
for j, k in enumerate(cosyvoice.inference_cross_lingual(tts_text, prompt_speech_16k, stream=False,speed=1)):
torch.cuda.manual_seed_all(time.time())
torchaudio.save('{}_{}_{}.wav'.format(prefix,i, j), k['tts_speech'], cosyvoice.sample_rate)
logging.info(f'Finished processing {prompt_text}')
if __name__ == '__main__':
from cosyvoice.cli.cosyvoice import CosyVoice2
import torch
import sys
# model_path = '/home/yueyulin/models/CosyVoice2-0.5B_RWKV_0.19B/'
# device = 'cuda:0'
print(sys.argv)
model_path = sys.argv[1]
device = sys.argv[2] if len(sys.argv) > 2 else 'cuda:0'
is_flow_only = sys.argv[3]=='True' if len(sys.argv) > 3 else False
print(f'is_flow_only: {is_flow_only}')
cosyvoice = CosyVoice2(model_path,device=device,fp16=False,load_jit=False)
from cosyvoice.utils.file_utils import load_wav
import torchaudio
prompt_audios = [
'/home/yueyulin/github/RWKVTTS/zero_shot_prompt.wav',
'/home/yueyulin/github/RWKVTTS/mine.wav',
'/home/yueyulin/github/RWKVTTS/new.wav',
'/home/yueyulin/github/RWKVTTS/Trump.wav',
]
if not is_flow_only:
prompt_texts = [
'希望你以后做的比我还好呦。',
'少年强则中国强。',
'我随便说一句话,我喊开始录就开始录。',
'numbers of Latino, African American, Asian American and native American voters.'
]
else:
prompt_texts = [
None,
None,
None,
None
]
do_tts('By unifying streaming and non-streaming synthesis within a single framework, CosyVoice 2 achieves human parity naturalness, minimal response latency, and virtually lossless synthesis quality in streaming mode. ',prompt_texts,cosyvoice,"en")
do_tts('一个教授逻辑学的教授,有三个学生,而且三个学生均非常聪明!一天教授给他们出了一个题,教授在每个人脑门上贴了一张纸条并告诉他们,每个人的纸条上都写了一个正整数,且某两个数的和等于第三个!',prompt_texts,cosyvoice,"cn")