Spaces:
Build error
Build error
Commit
·
84a239d
1
Parent(s):
40d6b94
Update app.py
Browse files
app.py
CHANGED
|
@@ -12,18 +12,19 @@ import json
|
|
| 12 |
import soundfile as sf
|
| 13 |
|
| 14 |
|
|
|
|
|
|
|
| 15 |
device = 0 if torch.cuda.is_available() else "cpu"
|
| 16 |
|
|
|
|
| 17 |
pipe = pipeline(
|
| 18 |
task="automatic-speech-recognition",
|
| 19 |
-
model="openai/whisper-
|
| 20 |
chunk_length_s=30,
|
| 21 |
device=device,
|
| 22 |
-
)
|
| 23 |
-
|
| 24 |
-
session_token = os.environ.get("SessionToken")
|
| 25 |
|
| 26 |
-
#
|
| 27 |
tacotron2 = Tacotron2.from_hparams(source="speechbrain/tts-tacotron2-ljspeech", savedir="tmpdir_tts", overrides={"max_decoder_steps": 2000}, run_opts={"device":device})
|
| 28 |
hifi_gan = HIFIGAN.from_hparams(source="speechbrain/tts-hifigan-ljspeech", savedir="tmpdir_vocoder")
|
| 29 |
|
|
@@ -46,7 +47,7 @@ def chat(input_audio, chat_history, reset_conversation):
|
|
| 46 |
# text -> response (chatGPT)
|
| 47 |
response = get_response_from_chatbot(message, reset_conversation)
|
| 48 |
|
| 49 |
-
# response -> speech (
|
| 50 |
mel_output, mel_length, alignment = tacotron2.encode_text(response)
|
| 51 |
wav = hifi_gan.decode_batch(mel_output)
|
| 52 |
sf.write("out.wav", wav.squeeze().cpu().numpy(), 22050)
|
|
@@ -150,6 +151,7 @@ start_work= """async() => {
|
|
| 150 |
|
| 151 |
with gr.Blocks(title="Talk to chatGPT") as demo:
|
| 152 |
gr.Markdown("## Talk to chatGPT ##")
|
|
|
|
| 153 |
gr.HTML("<p>You can duplicate this space and use your own session token: <a style='display:inline-block' href='https://huggingface.co/spaces/yizhangliu/chatGPT?duplicate=true'><img src='https://img.shields.io/badge/-Duplicate%20Space-blue?labelColor=white&style=flat&logo=&logoWidth=10' alt='Duplicate Space'></a></p>")
|
| 154 |
gr.HTML("<p> Instruction on how to get session token can be seen in video <a style='display:inline-block' href='https://www.youtube.com/watch?v=TdNSj_qgdFk'><font style='color:blue;weight:bold;'>here</font></a>. Add your session token by going to settings and add under secrets. </p>")
|
| 155 |
with gr.Group(elem_id="page_1", visible=True) as page_1:
|
|
|
|
| 12 |
import soundfile as sf
|
| 13 |
|
| 14 |
|
| 15 |
+
session_token = os.environ.get("SessionToken")
|
| 16 |
+
|
| 17 |
device = 0 if torch.cuda.is_available() else "cpu"
|
| 18 |
|
| 19 |
+
# Intialise STT (Whisper)
|
| 20 |
pipe = pipeline(
|
| 21 |
task="automatic-speech-recognition",
|
| 22 |
+
model="openai/whisper-base.en",
|
| 23 |
chunk_length_s=30,
|
| 24 |
device=device,
|
| 25 |
+
)
|
|
|
|
|
|
|
| 26 |
|
| 27 |
+
# Intialise TTS (tacotron2) and Vocoder (HiFIGAN)
|
| 28 |
tacotron2 = Tacotron2.from_hparams(source="speechbrain/tts-tacotron2-ljspeech", savedir="tmpdir_tts", overrides={"max_decoder_steps": 2000}, run_opts={"device":device})
|
| 29 |
hifi_gan = HIFIGAN.from_hparams(source="speechbrain/tts-hifigan-ljspeech", savedir="tmpdir_vocoder")
|
| 30 |
|
|
|
|
| 47 |
# text -> response (chatGPT)
|
| 48 |
response = get_response_from_chatbot(message, reset_conversation)
|
| 49 |
|
| 50 |
+
# response -> speech (tacotron2)
|
| 51 |
mel_output, mel_length, alignment = tacotron2.encode_text(response)
|
| 52 |
wav = hifi_gan.decode_batch(mel_output)
|
| 53 |
sf.write("out.wav", wav.squeeze().cpu().numpy(), 22050)
|
|
|
|
| 151 |
|
| 152 |
with gr.Blocks(title="Talk to chatGPT") as demo:
|
| 153 |
gr.Markdown("## Talk to chatGPT ##")
|
| 154 |
+
gr.HTML("<p> Demo uses <a href='https://huggingface.co/openai/whisper-base.en'>Whisper</a> to convert the input speech to transcribed text, <a href='https://chat.openai.com/chat'>chatGPT</a> to generate responses, and <a href='https://huggingface.co/speechbrain/tts-tacotron2-ljspeech'>tacotron2</a> to convert the response to output speech. </p>")
|
| 155 |
gr.HTML("<p>You can duplicate this space and use your own session token: <a style='display:inline-block' href='https://huggingface.co/spaces/yizhangliu/chatGPT?duplicate=true'><img src='https://img.shields.io/badge/-Duplicate%20Space-blue?labelColor=white&style=flat&logo=&logoWidth=10' alt='Duplicate Space'></a></p>")
|
| 156 |
gr.HTML("<p> Instruction on how to get session token can be seen in video <a style='display:inline-block' href='https://www.youtube.com/watch?v=TdNSj_qgdFk'><font style='color:blue;weight:bold;'>here</font></a>. Add your session token by going to settings and add under secrets. </p>")
|
| 157 |
with gr.Group(elem_id="page_1", visible=True) as page_1:
|