Fish Audio S2.1 Pro

Fish Audio S2.1 Pro is a flagship text-to-speech model built for highly expressive, low-latency speech generation. It supports natural-language bracket cues for emotion and delivery control, multi-speaker dialogue in a single generation, 80+ languages with automatic language detection, and realtime streaming with very fast time to first audio.

Complete technical specification for integration
Ready-to-use code snippets for common workflows
Step-by-step tutorials for advanced use cases
API Options
Platform-level options for task execution and delivery.
taskType
stringrequiredvalue: audioInferenceIdentifier for the type of task being performed
taskUUID
stringrequiredUUID v4UUID v4 identifier for tracking tasks and matching async responses. Must be unique per task.
outputType
stringdefault: URLAudio output type.
Allowed values3 values
outputFormat
stringdefault: MP3Specifies the file format of the generated output. The available values depend on the task type and the specific model's capabilities.
- `MP3`: Compressed audio, smaller file size.
- `WAV`: Uncompressed, high-quality audio.
- `FLAC`: Lossless compression.
- `OGG`: Open-source compressed audio format (Vorbis codec).
Allowed values4 values
audioSettings
objectAudio encoding settings for controlling the bitrate, number of channels, and sample rate of the generated audio. Only applicable for lossy output formats (
MP3andOGG). When using lossless formats (WAVorFLAC), this parameter must not be provided.The available sample rates and valid bitrate ranges depend on the output format. For
OGG, bitrate limits also vary by the number of channels.MP3 bitrate limits
Bitrate limits for MP3 are the same regardless of mono or stereo.
Sample Rate Min Bitrate Max Bitrate 8,000 Hz 8 kbps 64 kbps 11,025 Hz 8 kbps 64 kbps 12,000 Hz 8 kbps 64 kbps 16,000 Hz 8 kbps 160 kbps 22,050 Hz 8 kbps 160 kbps 24,000 Hz 8 kbps 160 kbps 32,000 Hz 32 kbps 320 kbps 44,100 Hz 32 kbps 320 kbps 48,000 Hz 32 kbps 320 kbps OGG bitrate limits — Mono (1 channel)
Sample Rate Min Bitrate Max Bitrate 8,000 Hz 8 kbps 40 kbps 12,000 Hz 16 kbps 48 kbps 16,000 Hz 16 kbps 96 kbps 24,000 Hz 16 kbps 80 kbps 48,000 Hz 32 kbps 224 kbps OGG bitrate limits — Stereo (2 channels)
Sample Rate Min Bitrate Max Bitrate 8,000 Hz 16 kbps 80 kbps 12,000 Hz 16 kbps 96 kbps 16,000 Hz 24 kbps 192 kbps 24,000 Hz 32 kbps 160 kbps 48,000 Hz 48 kbps 256 kbps Lossless formats: When
outputFormatis set toWAVorFLAC, theaudioSettingsparameter is not available since these formats produce uncompressed or lossless audio with no configurable encoding settings.Properties3 properties
audioSettings»bitratebitrate
integermin: 8Audio bitrate in kbps.
audioSettings»channelschannels
integerdefault: 2Number of audio channels. 1 for mono, 2 for stereo.
Allowed values2 values
audioSettings»sampleRatesampleRate
integerAudio sample rate in Hz.
webhookURL
stringURISpecifies a webhook URL where JSON responses will be sent via HTTP POST when generation tasks complete. For batch requests with multiple results, each completed item triggers a separate webhook call as it becomes available.
Learn more1 resource
- WebhooksPLATFORM
- Webhooks
deliveryMethod
stringdefault: syncDetermines how the API delivers task results.
Allowed values2 values
- Returns complete results directly in the API response.
- Returns an immediate acknowledgment with the task UUID. Poll for results using getResponse.
Learn more1 resource
- Task PollingPLATFORM
uploadEndpoint
stringURISpecifies a URL where the generated content will be automatically uploaded using the HTTP PUT method. The raw binary data of the media file is sent directly as the request body. For secure uploads to cloud storage, use presigned URLs that include temporary authentication credentials.
Common use cases:
- Cloud storage: Upload directly to S3 buckets, Google Cloud Storage, or Azure Blob Storage using presigned URLs.
- CDN integration: Upload to content delivery networks for immediate distribution.
// S3 presigned URL for secure upload https://your-bucket.s3.amazonaws.com/generated/content.mp4?X-Amz-Signature=abc123&X-Amz-Expires=3600 // Google Cloud Storage presigned URL https://storage.googleapis.com/your-bucket/content.jpg?X-Goog-Signature=xyz789 // Custom storage endpoint https://storage.example.com/uploads/generated-image.jpgThe content data will be sent as the request body to the specified URL when generation is complete.
ttl
integermin: 60Time-to-live (TTL) in seconds for generated content. Only applies when
outputTypeisURL.
includeCost
booleandefault: falseInclude task cost in the response.
numberResults
integermin: 1max: 4default: 1Number of results to generate. Each result uses a different seed, producing variations of the same parameters.
Inputs
Input resources for the task (images, audio, etc). These must be nested inside the inputs object.
inputs object.inputs»referenceVoicesreferenceVoices
array of objectsitems: 1Inline voice reference for zero-shot voice cloning. Single-speaker only.
Properties2 properties
inputs»referenceVoices»audioaudio
stringrequiredReference audio clip for the voice to clone (UUID, URL, DataURI, or Base64). Audio duration must be between 1.0 and 90.0 seconds.
inputs»referenceVoices»texttext
stringrequiredmin: 1max: 1000Transcript of the reference audio clip. Must match the spoken content of the reference audio.
Core Parameters
Primary parameters that define the task output.
model
stringrequiredvalue: fishaudio:s2.1@proIdentifier of the model to use for generation.
Learn more3 resources
speech
objectrequiredSettings for speech generation.
Properties5 properties
speech»texttext
stringrequiredmin: 1max: 3000Text to convert to speech. For multi-speaker dialogue, embed inline speaker tags such as
<|speaker:0|>and<|speaker:1|>. Bracket-style paralinguistic cues such as[laughs],[sigh],[short pause], and[whispering]can also be embedded inline.
speech»voicevoice
stringVoice model ID from the Fish Audio voice library or a custom voice. Browse all available voices at https://api.fish.audio/model?page_size=100&page_number=1&sort_by=score.
Allowed values8 values
- Egirl — A cute e-girl to chat with you.
- Selene — A meditative female voice.
- Adrian — A steady and reliable narrator.
- Sarah — An engaged speaker.
- Ethan — A curious explainer.
- Laura — A confident female narrator.
- Jordan — A motivational speaker.
- Hannah — A conversation specialist.
speech»voicesvoices
array of stringsitems: 2Voice model IDs for multi-speaker dialogue. Speaker tags in
speech.textsuch as<|speaker:0|>and<|speaker:1|>map to the matching array index.
speech»volumevolume
floatdefault: 0Volume adjustment in decibels.
0= no change.
speech»speedspeed
floatmin: 0.5max: 2step: 0.01default: 1Playback speed of the generated speech.
Settings
Technical parameters to fine-tune the inference process. These must be nested inside the settings object.
settings object.settings»temperaturetemperature
floatmin: 0max: 1step: 0.01default: 0.7Expressiveness of the generated speech.
settings»topPtopP
floatmin: 0.0001max: 1step: 0.01default: 0.7Nucleus sampling parameter that controls diversity by limiting the probability mass. Lower values make outputs more focused, higher values increase diversity.
settings»chunkLengthchunkLength
integermin: 100max: 300default: 300Text segment size for processing.
settings»conditionOnPreviousChunksconditionOnPreviousChunks
booleandefault: truePrevious audio context for voice consistency across chunks.
settings»earlyStopThresholdearlyStopThreshold
floatmin: 0max: 1default: 1Early stopping threshold for batch processing.
settings»latencylatency
stringdefault: normalLatency / quality trade-off.
Allowed values3 values
- Fastest response, lower quality.
- Balanced default.
- Highest quality, slower.
settings»maxTokensmaxTokens
integermin: 1max: 4294967295default: 1024Maximum audio tokens to generate per text chunk.
settings»minChunkLengthminChunkLength
integermin: 0max: 100default: 50Minimum characters before splitting into a new chunk.
settings»normalizenormalize
booleandefault: trueText normalization for English and Chinese. Improves stability for numbers.
settings»normalizeLoudnessnormalizeLoudness
booleandefault: trueNormalize output loudness for consistent perceived volume.
settings»repetitionPenaltyrepetitionPenalty
floatmin: 0max: 2step: 0.01default: 1.2Penalty for repeating audio patterns.