Inworld TTS 1.5 Max
Text-to-Speech • Inworld • ProxiedHighest-quality text-to-speech with under 200ms latency, emotion control, and 15-language support.
| Model Info | |
|---|---|
| Terms and License | link ↗ |
| More information | link ↗ |
| Pricing | View pricing in the Cloudflare dashboard ↗ |
Usage
const response = await env.AI.run( 'inworld/tts-1.5-max', { text: 'Hello! Welcome to Cloudflare AI Gateway. Let me show you what we can do.', voice_id: 'Dennis', output_format: 'mp3', temperature: 1, timestamp_type: 'none', }, { gateway: { id: 'default' }, })console.log(response){ "state": "Completed", "result": { "audio": "https://pub-04a6d208d361438ea01b797e6973bd19.r2.dev/catalog/inworld__tts-1.5-max/simple-speech.mp3" }, "gatewayMetadata": { "keySource": "Unified" }}Examples
Slow Narration — Slower speech for narration
const response = await env.AI.run( 'inworld/tts-1.5-max', { text: 'In the beginning, the universe was a singularity of infinite density. Then, in a fraction of a second, it expanded into everything we know today.', voice_id: 'Dennis', output_format: 'mp3', speaking_rate: 0.85, temperature: 1, timestamp_type: 'none', }, { gateway: { id: 'default' }, })console.log(response){ "state": "Completed", "result": { "audio": "https://pub-04a6d208d361438ea01b797e6973bd19.r2.dev/catalog/inworld__tts-1.5-max/slow-narration.mp3" }, "gatewayMetadata": { "keySource": "Unified" }}High Quality Audio — Higher sample rate for studio quality
const response = await env.AI.run( 'inworld/tts-1.5-max', { text: 'This recording is generated at studio quality for the best possible listening experience.', voice_id: 'Dennis', output_format: 'mp3', sample_rate: 48000, temperature: 1, timestamp_type: 'none', }, { gateway: { id: 'default' }, })console.log(response){ "state": "Completed", "result": { "audio": "https://pub-04a6d208d361438ea01b797e6973bd19.r2.dev/catalog/inworld__tts-1.5-max/high-quality-audio.mp3" }, "gatewayMetadata": { "keySource": "Unified" }}With Text Normalization — Expand numbers and abbreviations before synthesis
const response = await env.AI.run( 'inworld/tts-1.5-max', { text: 'The meeting is at 3:30 PM on Jan 15th, 2026. Please confirm by calling 555-0123.', voice_id: 'Dennis', output_format: 'mp3', temperature: 1, timestamp_type: 'none', apply_text_normalization: true, }, { gateway: { id: 'default' }, })console.log(response){ "state": "Completed", "result": { "audio": "https://pub-04a6d208d361438ea01b797e6973bd19.r2.dev/catalog/inworld__tts-1.5-max/with-text-normalization.mp3" }, "gatewayMetadata": { "keySource": "Unified" }}Parameters
stringrequiredmaxLength: 2000The text to be synthesized into speech. Maximum input of 2,000 characters.stringrequireddefault: Dennisenum: Loretta, Darlene, Marlene, Hank, Evelyn, Celeste, Pippa, Tessa, Liam, Callum, Hamish, Abby, Graham, Rupert, Mortimer, Snik, Anjali, Saanvi, Arjun, Claire, Oliver, Simon, Elliot, James, Serena, Gareth, Vinny, Lauren, Jessica, Ethan, Tyler, Jason, Chloe, Veronica, Victoria, Miranda, Sebastian, Victor, Malcolm, Nate, Brian, Amina, Kelsey, Derek, Evan, Kayla, Jake, Grant, Tristan, Nadia, Selene, Marcus, Riley, Damon, Cedric, Mia, Naomi, Jonah, Levi, Avery, Brandon, Conrad, Bianca, Lucian, Trevor, Alex, Ashley, Craig, Deborah, Dennis, Edward, Elizabeth, Hades, Julia, Pixie, Mark, Olivia, Priya, Ronald, Sarah, Shaun, Theodore, Timothy, Wendy, Dominus, Hana, Clive, Carter, Blake, Luna, Reed, Duncan, Felix, Eleanor, SophieThe ID of the voice to use for synthesizing speech. Defaults to Dennis.stringrequireddefault: mp3enum: mp3, opus, wav, flacThe output format for the audio. Supported formats are mp3, opus, wav, and flac. Defaults to mp3.integerminimum: -9007199254740991maximum: 9007199254740991Bits per second of the audio. Only for compressed audio formats (mp3, opus). The default is 128,000.integerminimum: -9007199254740991maximum: 9007199254740991The synthesis sample rate in hertz. Accepts: 8000, 16000, 22050, 24000, 32000, 44100, 48000. The default is 48,000.numberminimum: 0.5maximum: 1.5Speaking rate/speed, in the range [0.5, 1.5]. The default is 1.0. We recommend using values above 0.8 to ensure high quality.numberrequireddefault: 1minimum: 0.01maximum: 2Determines the degree of randomness when sampling audio tokens. Defaults to 1.0. Accepts values between 0 (exclusive) and 2 (inclusive). Higher values = more expressive, lower values = more deterministic.stringrequireddefault: noneenum: none, word, characterControls timestamp metadata returned with the audio. "word" returns word-level timing, "character" returns character-level timing. Note: adds latency. Defaults to none.booleanWhen enabled, text normalization expands numbers, dates, times, and abbreviations before converting to speech. Turning this off may reduce latency.stringURL to the generated audio file