File size: 936 Bytes
fbda3c1
 
 
1f53454
7882aea
 
fbda3c1
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
from elevenlabs import voices, generate, set_api_key, UnauthenticatedRateLimitError
import numpy as np
import gradio as gr

set_api_key('ELEVEN_API_KEY')

def pad_buffer(audio):
    # Pad buffer to multiple of 2 bytes
    buffer_size = len(audio)
    element_size = np.dtype(np.int16).itemsize
    if buffer_size % element_size != 0:
        audio = audio + b'\0' * (element_size - (buffer_size % element_size))
    return audio 

def generate_audio(text):
    try:
        audio = generate(
            text[:250], # Limit to 250 characters
            voice="Arnold", 
            model="eleven_multilingual_v1"
        )
        return (44100, np.frombuffer(pad_buffer(audio), dtype=np.int16))
    except UnauthenticatedRateLimitError as e:
        raise gr.Error("Thanks for trying out ElevenLabs TTS! You've reached the free tier limit. Please provide an API key to continue.") 
    except Exception as e:
        raise gr.Error(e)