Documentation Index
Fetch the complete documentation index at: https://daily-docs-pr-4535.mintlify.app/llms.txt
Use this file to discover all available pages before exploring further.
Overview
Smallest AI provides real-time text-to-speech synthesis through a WebSocket-based integration with their Waves API. The service supports configurable voice parameters, multiple languages, and handles interruptions by reconnecting the WebSocket.Smallest AI TTS API Reference
Complete API reference for all parameters and methods
Example Implementation
Complete example with WebSocket streaming
Installation
Prerequisites
- Smallest AI Account: Sign up at Smallest AI
- API Key: Generate an API key from your account dashboard
Configuration
Smallest AI API key for authentication.
Base WebSocket URL for the Smallest API. Override for custom or proxied
deployments.
Output audio sample rate in Hz. When
None, uses the pipeline’s configured
sample rate.Audio format returned by the API. One of
pcm, mp3, wav, ulaw, alaw.
Defaults to pcm, which is what Pipecat expects internally. Fixed at init
time.Runtime-configurable settings. See Settings below.
Settings
Runtime-configurable settings passed via thesettings constructor argument using SmallestTTSService.Settings(...). These can be updated mid-conversation with TTSUpdateSettingsFrame. See Service Settings for details.
| Parameter | Type | Default | Description |
|---|---|---|---|
model | str | lightning_v3.1_pro | Model identifier: lightning_v3.1 or lightning_v3.1_pro. |
voice | str | meher | Voice identifier. Default is meher for lightning_v3.1_pro. |
language | Language | str | Language.EN | Language code for synthesis. |
speed | float | None | Speech speed multiplier (0.5–2.0). When None, uses API defaults. |
Usage
Basic Setup
With Voice Customization
Updating Settings at Runtime
Voice settings can be changed mid-conversation usingTTSUpdateSettingsFrame:
Notes
- WebSocket streaming: The service uses WebSocket connections for real-time streaming. The connection is automatically managed and will reconnect if interrupted.
- Keepalive: The service sends periodic keepalive messages (every 30 seconds) to prevent idle timeouts on the WebSocket connection.
- Language support: Supports multiple languages including Arabic, Bengali, German, English, Spanish, French, Gujarati, Hebrew, Hindi, Italian, Kannada, Marathi, Dutch, Polish, Russian, and Tamil.
Event Handlers
Smallest AI TTS supports the standard service connection events:| Event | Description |
|---|---|
on_connected | Connected to Smallest AI WebSocket |
on_disconnected | Disconnected from Smallest WebSocket |
on_connection_error | WebSocket connection error occurred |