Documentation Index
Fetch the complete documentation index at: https://assemblyai.com/docs/llms.txt
Use this file to discover all available pages before exploring further.
Supported languages
Supported languages
Supported models
Supported models
Supported regions
Supported regions
US & EU
Want to name your speakers?Speaker Diarization assigns generic labels like “Speaker A” and “Speaker B” to
distinguish between speakers. If you want to replace these labels with actual
names or roles (e.g., “John Smith” or “Customer”), use Speaker
Identification. Speaker
Identification analyzes the conversation content to infer who is speaking and
transforms your transcript from generic labels to meaningful identifiers.
Quickstart
- Python
- Python SDK
- JavaScript
- JavaScript SDK
To enable Speaker Diarization, set
speaker_labels to True in the POST request body:import requests
import time
base_url = "https://api.assemblyai.com"
headers = {
"authorization": "<YOUR_API_KEY>"
}
with open("./my-audio.mp3", "rb") as f:
response = requests.post(base_url + "/v2/upload",
headers=headers,
data=f)
upload_url = response.json()["upload_url"]
data = {
"audio_url": upload_url, # You can also use a URL to an audio or video file on the web
"speech_models": ["universal-3-pro", "universal-2"],
"language_detection": True,
"speaker_labels": True
}
url = base_url + "/v2/transcript"
response = requests.post(url, json=data, headers=headers)
transcript_id = response.json()['id']
polling_endpoint = base_url + "/v2/transcript/" + transcript_id
while True:
transcription_result = requests.get(polling_endpoint, headers=headers).json()
if transcription_result['status'] == 'completed':
print(f"Transcript ID: {transcript_id}")
break
elif transcription_result['status'] == 'error':
raise RuntimeError(f"Transcription failed: {transcription_result['error']}")
else:
time.sleep(3)
for utterance in transcription_result['utterances']:
print(f"Speaker {utterance['speaker']}: {utterance['text']}")
To enable Speaker Diarization, set
speaker_labels to True in the transcription config.import assemblyai as aai
aai.settings.api_key = "<YOUR_API_KEY>"
# You can use a local filepath:
# audio_file = "./example.mp3"
# Or use a publicly-accessible URL:
audio_file = (
"https://assembly.ai/wildfires.mp3"
)
config = aai.TranscriptionConfig(
speech_models=["universal-3-pro", "universal-2"],
language_detection=True,
speaker_labels=True,
)
transcript = aai.Transcriber().transcribe(audio_file, config)
for utterance in transcript.utterances:
print(f"Speaker {utterance.speaker}: {utterance.text}")
To enable Speaker Diarization, set
speaker_labels to true in the POST request body:import fs from "fs-extra";
const baseUrl = "https://api.assemblyai.com";
const headers = {
authorization: "<YOUR_API_KEY>",
};
const path = "./audio/audio.mp3";
const audioData = await fs.readFile(path);
let res = await fetch(`${baseUrl}/v2/upload`, {
method: "POST",
headers,
body: audioData,
});
if (!res.ok) throw new Error(`Error: ${res.status}`);
const uploadResponse = await res.json();
const uploadUrl = uploadResponse.upload_url;
const data = {
audio_url: uploadUrl, // You can also use a URL to an audio or video file on the web
speech_models: ["universal-3-pro", "universal-2"],
language_detection: true,
speaker_labels: true,
};
const url = `${baseUrl}/v2/transcript`;
res = await fetch(url, {
method: "POST",
headers: { ...headers, "Content-Type": "application/json" },
body: JSON.stringify(data),
});
if (!res.ok) throw new Error(`Error: ${res.status}`);
const response = await res.json();
const transcriptId = response.id;
const pollingEndpoint = `${baseUrl}/v2/transcript/${transcriptId}`;
while (true) {
res = await fetch(pollingEndpoint, { headers });
if (!res.ok) throw new Error(`Error: ${res.status}`);
const transcriptionResult = await res.json();
if (transcriptionResult.status === "completed") {
for (const utterance of transcriptionResult.utterances) {
console.log(`Speaker ${utterance.speaker}: ${utterance.text}`);
}
break;
} else if (transcriptionResult.status === "error") {
throw new Error(`Transcription failed: ${transcriptionResult.error}`);
} else {
await new Promise((resolve) => setTimeout(resolve, 3000));
}
}
To enable Speaker Diarization, set
speaker_labels to true in the transcription config.import { AssemblyAI } from "assemblyai";
const client = new AssemblyAI({
apiKey: "<YOUR_API_KEY>",
});
// You can use a local filepath:
// const audioFile = "./example.mp3"
// Or use a publicly-accessible URL:
const audioFile = "https://assembly.ai/wildfires.mp3";
const params = {
audio: audioFile,
speech_models: ["universal-3-pro", "universal-2"],
language_detection: true,
speaker_labels: true,
};
const run = async () => {
const transcript = await client.transcripts.transcribe(params);
for (const utterance of transcript.utterances ?? []) {
console.log(`Speaker ${utterance.speaker}: ${utterance.text}`);
}
};
run();
Example output
Speaker A: Smoke from hundreds of wildfires in Canada is triggering air quality alerts
throughout the US. Skylines from Maine to Maryland to Minnesota are gray and smoggy.
And in some places, the weights of the air qualitative index has exceeded 300.
Speaker B: Well, we have seen in the past when smoke from prior years and prior fires
has come up from prior years to the east coast. But this particular time around,
it's been notable in just how much of the of the country has been affected.
The default upper limit on the number of speakers depends on the audio duration:
- 0–2 minutes: no max speaker limit
- 2–10 minutes: max 10 speakers
- 10+ minutes: max 30 speakers
speaker_options to
set a range of possible
speakers.Set number of speakers expected
You can set the number of speakers expected in the audio file by setting thespeakers_expected parameter.
Only use this parameter if you are certain about the number of speakers in the
audio file.
speakers_expected to your transcription config:
- Python
- Python SDK
- JavaScript
- JavaScript SDK
data = {
"audio_url": upload_url,
"speech_models": ["universal-3-pro", "universal-2"],
"language_detection": True,
"speaker_labels": True,
"speakers_expected": 5
}
config = aai.TranscriptionConfig(
speech_models=["universal-3-pro", "universal-2"],
language_detection=True,
speaker_labels=True,
speakers_expected=5,
)
const data = {
audio_url: uploadUrl,
speech_models: ["universal-3-pro", "universal-2"],
language_detection: true,
speaker_labels: true,
speakers_expected: 5,
};
const params = {
audio: audioFile,
speech_models: ["universal-3-pro", "universal-2"],
language_detection: true,
speaker_labels: true,
speakers_expected: 5,
};
Set a range of possible speakers
You can set a range of possible speakers in the audio file by setting thespeaker_options parameter. By default, the maximum number of speakers depends on the audio duration (no limit for 0–2 minutes, 10 for 2–10 minutes, and 30 for 10+ minutes).
This parameter is suitable for use cases where there is a known minimum/maximum number of speakers in the audio file that is outside the bounds of the default limits.
Setting
max_speakers_expected too high may reduce diarization accuracy,
causing sentences from the same speaker to be split across multiple speaker
labels.When using
multichannel with speaker_labels, the speaker_options parameters are applied per channel, not globally across the entire file. For example, setting min_speakers_expected: 5 and max_speakers_expected: 7 on a 5-channel file means the model will find 5–7 speakers on each channel, resulting in 25–35 total speakers. Adjust your speaker options accordingly when using multichannel transcription.speaker_options to your transcription config:
- Python
- Python SDK
- JavaScript
- JavaScript SDK
data = {
"audio_url": upload_url,
"speech_models": ["universal-3-pro", "universal-2"],
"language_detection": True,
"speaker_labels": True,
"speaker_options": {
"min_speakers_expected": 3,
"max_speakers_expected": 5
}
}
config = aai.TranscriptionConfig(
speech_models=["universal-3-pro", "universal-2"],
language_detection=True,
speaker_labels=True,
speaker_options=aai.SpeakerOptions(
min_speakers_expected=3,
max_speakers_expected=5
),
)
const data = {
audio_url: uploadUrl,
speech_models: ["universal-3-pro", "universal-2"],
language_detection: true,
speaker_labels: true,
speaker_options: {
min_speakers_expected: 3,
max_speakers_expected: 5,
},
};
const params = {
audio: audioFile,
speech_models: ["universal-3-pro", "universal-2"],
language_detection: true,
speaker_labels: true,
speaker_options: {
min_speakers_expected: 3,
max_speakers_expected: 5,
},
};
API reference
Request
Speakers Expectedcurl https://api.assemblyai.com/v2/transcript \
--header "Authorization: <YOUR_API_KEY>" \
--header "Content-Type: application/json" \
--data '{
"audio_url": "YOUR_AUDIO_URL",
"speech_models": ["universal-3-pro", "universal-2"],
"language_detection": true,
"speaker_labels": true,
"speakers_expected": 3
}'
curl https://api.assemblyai.com/v2/transcript \
--header "Authorization: <YOUR_API_KEY>" \
--header "Content-Type: application/json" \
--data '{
"audio_url": "YOUR_AUDIO_URL",
"speech_models": ["universal-3-pro", "universal-2"],
"language_detection": true,
"speaker_labels": true,
"speaker_options": {
"min_speakers_expected": 3,
"max_speakers_expected": 5
}
}'
| Key | Type | Description |
|---|---|---|
speaker_labels | boolean | Enable Speaker Diarization. |
speakers_expected | number | Set number of speakers. |
speaker_options | object | Set range of possible speakers. |
speaker_options.min_speakers_expected | number | The minimum number of speakers expected in the audio file. |
speaker_options.max_speakers_expected | number | The maximum number of speakers expected in the audio file. |
Response
{
utterances: [
{
confidence: 0.9359033333333334,
end: 26950,
speaker: "A",
start: 250,
text: "Smoke from hundreds of wildfires in Canada is triggering air quality alerts throughout the US. Skylines from Maine to Maryland to Minnesota are gray and smoggy. And in some places, the air quality warnings include the warning to stay inside. We wanted to better understand what's happening here and why, so we called Peter de Carlo, an associate professor in the Department of Environmental Health and Engineering at Johns Hopkins University Varsity. Good morning, professor.",
words: [
{
text: "Smoke",
start: 250,
end: 650,
confidence: 0.97503,
speaker: "A",
},
{
text: "from",
start: 730,
end: 1022,
confidence: 0.99999,
speaker: "A",
},
{
text: "hundreds",
start: 1076,
end: 1418,
confidence: 0.99843,
speaker: "A",
},
{
text: "of",
start: 1434,
end: 1614,
confidence: 0.85,
speaker: "A",
},
{
text: "wildfires",
start: 1652,
end: 2346,
confidence: 0.89657,
speaker: "A",
},
{
text: "in",
start: 2378,
end: 2526,
confidence: 0.99994,
speaker: "A",
},
{
text: "Canada",
start: 2548,
end: 3130,
confidence: 0.93864,
speaker: "A",
},
{
text: "is",
start: 3210,
end: 3454,
confidence: 0.999,
speaker: "A",
},
{
text: "triggering",
start: 3492,
end: 3946,
confidence: 0.75366,
speaker: "A",
},
{
text: "air",
start: 3978,
end: 4174,
confidence: 1.0,
speaker: "A",
},
{
text: "quality",
start: 4212,
end: 4558,
confidence: 0.87745,
speaker: "A",
},
{
text: "alerts",
start: 4644,
end: 5114,
confidence: 0.94739,
speaker: "A",
},
{
text: "throughout",
start: 5162,
end: 5466,
confidence: 0.99726,
speaker: "A",
},
{
text: "the",
start: 5498,
end: 5694,
confidence: 0.79,
speaker: "A",
},
{
text: "US.",
start: 5732,
end: 6382,
confidence: 0.88,
speaker: "A",
},
{
text: "Skylines",
start: 6516,
end: 7226,
confidence: 0.94906,
speaker: "A",
},
{
text: "from",
start: 7258,
end: 7454,
confidence: 0.99997,
speaker: "A",
},
{
text: "Maine",
start: 7492,
end: 7914,
confidence: 0.46929,
speaker: "A",
},
{
text: "to",
start: 7962,
end: 8174,
confidence: 1.0,
speaker: "A",
},
{
text: "Maryland",
start: 8212,
end: 8634,
confidence: 0.99855,
speaker: "A",
},
{
text: "to",
start: 8682,
end: 8894,
confidence: 1.0,
speaker: "A",
},
{
text: "Minnesota",
start: 8932,
end: 9578,
confidence: 0.93339,
speaker: "A",
},
{
text: "are",
start: 9674,
end: 9934,
confidence: 0.99978,
speaker: "A",
},
{
text: "gray",
start: 9972,
end: 10186,
confidence: 0.68,
speaker: "A",
},
{
text: "and",
start: 10218,
end: 10414,
confidence: 1.0,
speaker: "A",
},
{
text: "smoggy.",
start: 10452,
end: 11050,
confidence: 0.99223,
speaker: "A",
},
{
text: "And",
start: 11130,
end: 11326,
confidence: 1.0,
speaker: "A",
},
{
text: "in",
start: 11348,
end: 11534,
confidence: 0.9947,
speaker: "A",
},
{
text: "some",
start: 11572,
end: 11774,
confidence: 1.0,
speaker: "A",
},
{
text: "places,",
start: 11812,
end: 12106,
confidence: 0.99991,
speaker: "A",
},
{
text: "the",
start: 12138,
end: 12286,
confidence: 0.9,
speaker: "A",
},
{
text: "air",
start: 12308,
end: 12494,
confidence: 0.99995,
speaker: "A",
},
{
text: "quality",
start: 12532,
end: 12830,
confidence: 0.9966,
speaker: "A",
},
{
text: "warnings",
start: 12900,
end: 13434,
confidence: 0.99939,
speaker: "A",
},
{
text: "include",
start: 13482,
end: 13866,
confidence: 0.99998,
speaker: "A",
},
{
text: "the",
start: 13898,
end: 13998,
confidence: 1.0,
speaker: "A",
},
{
text: "warning",
start: 14004,
end: 14234,
confidence: 0.94734,
speaker: "A",
},
{
text: "to",
start: 14282,
end: 14542,
confidence: 0.95,
speaker: "A",
},
{
text: "stay",
start: 14596,
end: 14910,
confidence: 0.99999,
speaker: "A",
},
{
text: "inside.",
start: 14980,
end: 15646,
confidence: 0.99997,
speaker: "A",
},
{
text: "We",
start: 15828,
end: 16126,
confidence: 0.99997,
speaker: "A",
},
{
text: "wanted",
start: 16148,
end: 16334,
confidence: 0.99817,
speaker: "A",
},
{
text: "to",
start: 16372,
end: 16526,
confidence: 1.0,
speaker: "A",
},
{
text: "better",
start: 16548,
end: 16734,
confidence: 0.99999,
speaker: "A",
},
{
text: "understand",
start: 16772,
end: 17070,
confidence: 1.0,
speaker: "A",
},
{
text: "what's",
start: 17140,
end: 17466,
confidence: 0.99955,
speaker: "A",
},
{
text: "happening",
start: 17498,
end: 17742,
confidence: 0.99999,
speaker: "A",
},
{
text: "here",
start: 17796,
end: 17966,
confidence: 1.0,
speaker: "A",
},
{
text: "and",
start: 17988,
end: 18174,
confidence: 0.54,
speaker: "A",
},
{
text: "why,",
start: 18212,
end: 18414,
confidence: 0.99999,
speaker: "A",
},
{
text: "so",
start: 18452,
end: 18606,
confidence: 0.99974,
speaker: "A",
},
{
text: "we",
start: 18628,
end: 18766,
confidence: 0.98861,
speaker: "A",
},
{
text: "called",
start: 18788,
end: 18926,
confidence: 0.99987,
speaker: "A",
},
{
text: "Peter",
start: 18948,
end: 19274,
confidence: 0.99971,
speaker: "A",
},
{
text: "de",
start: 19322,
end: 19486,
confidence: 0.59364,
speaker: "A",
},
{
text: "Carlo,",
start: 19508,
end: 19930,
confidence: 0.73053,
speaker: "A",
},
{
text: "an",
start: 20010,
end: 20254,
confidence: 0.97545,
speaker: "A",
},
{
text: "associate",
start: 20292,
end: 20746,
confidence: 0.98965,
speaker: "A",
},
{
text: "professor",
start: 20778,
end: 21194,
confidence: 0.99117,
speaker: "A",
},
{
text: "in",
start: 21242,
end: 21358,
confidence: 0.99997,
speaker: "A",
},
{
text: "the",
start: 21364,
end: 21486,
confidence: 1.0,
speaker: "A",
},
{
text: "Department",
start: 21508,
end: 21834,
confidence: 0.99998,
speaker: "A",
},
{
text: "of",
start: 21882,
end: 22046,
confidence: 1.0,
speaker: "A",
},
{
text: "Environmental",
start: 22068,
end: 22666,
confidence: 0.53495,
speaker: "A",
},
{
text: "Health",
start: 22698,
end: 22942,
confidence: 0.9976,
speaker: "A",
},
{
text: "and",
start: 22996,
end: 23214,
confidence: 1.0,
speaker: "A",
},
{
text: "Engineering",
start: 23252,
end: 23706,
confidence: 0.99983,
speaker: "A",
},
{
text: "at",
start: 23738,
end: 23934,
confidence: 1.0,
speaker: "A",
},
{
text: "Johns",
start: 23972,
end: 24266,
confidence: 0.9997,
speaker: "A",
},
{
text: "Hopkins",
start: 24298,
end: 24714,
confidence: 0.99874,
speaker: "A",
},
{
text: "University",
start: 24762,
end: 25042,
confidence: 0.93732,
speaker: "A",
},
{
text: "Varsity.",
start: 25066,
end: 25490,
confidence: 0.47413,
speaker: "A",
},
{
text: "Good",
start: 25570,
end: 25766,
confidence: 0.73108,
speaker: "A",
},
{
text: "morning,",
start: 25788,
end: 26022,
confidence: 0.99997,
speaker: "A",
},
{
text: "professor.",
start: 26076,
end: 26950,
confidence: 0.99999,
speaker: "A",
},
],
},
{
confidence: 0.9929600000000001,
end: 28840,
speaker: "B",
start: 27850,
text: "Good morning.",
words: [
{
text: "Good",
start: 27850,
end: 28214,
confidence: 0.99999,
speaker: "B",
},
{
text: "morning.",
start: 28252,
end: 28840,
confidence: 0.98593,
speaker: "B",
},
],
},
{
confidence: 0.8863582608695653,
end: 37400,
speaker: "A",
start: 29610,
text: "What is it about the conditions right now that have caused this round of wildfires to affect so many people so far away?",
words: [
{
text: "What",
start: 29610,
end: 29926,
confidence: 0.9999,
speaker: "A",
},
{
text: "is",
start: 29948,
end: 30134,
confidence: 0.88563,
speaker: "A",
},
{
text: "it",
start: 30172,
end: 30278,
confidence: 0.99993,
speaker: "A",
},
{
text: "about",
start: 30284,
end: 30502,
confidence: 0.61503,
speaker: "A",
},
{
text: "the",
start: 30556,
end: 30726,
confidence: 1.0,
speaker: "A",
},
{
text: "conditions",
start: 30748,
end: 31314,
confidence: 0.77568,
speaker: "A",
},
{
text: "right",
start: 31362,
end: 31622,
confidence: 1.0,
speaker: "A",
},
{
text: "now",
start: 31676,
end: 32086,
confidence: 1.0,
speaker: "A",
},
{
text: "that",
start: 32188,
end: 32406,
confidence: 0.99998,
speaker: "A",
},
{
text: "have",
start: 32428,
end: 32614,
confidence: 0.76635,
speaker: "A",
},
{
text: "caused",
start: 32652,
end: 33026,
confidence: 0.81005,
speaker: "A",
},
{
text: "this",
start: 33058,
end: 33254,
confidence: 1.0,
speaker: "A",
},
{
text: "round",
start: 33292,
end: 33506,
confidence: 0.98965,
speaker: "A",
},
{
text: "of",
start: 33538,
end: 33782,
confidence: 0.63,
speaker: "A",
},
{
text: "wildfires",
start: 33836,
end: 34546,
confidence: 0.80401,
speaker: "A",
},
{
text: "to",
start: 34578,
end: 34726,
confidence: 1.0,
speaker: "A",
},
{
text: "affect",
start: 34748,
end: 35074,
confidence: 0.9824,
speaker: "A",
},
{
text: "so",
start: 35122,
end: 35334,
confidence: 0.66533,
speaker: "A",
},
{
text: "many",
start: 35372,
end: 35574,
confidence: 0.99999,
speaker: "A",
},
{
text: "people",
start: 35612,
end: 36054,
confidence: 0.5659,
speaker: "A",
},
{
text: "so",
start: 36172,
end: 36502,
confidence: 0.9931,
speaker: "A",
},
{
text: "far",
start: 36556,
end: 36774,
confidence: 1.0,
speaker: "A",
},
{
text: "away?",
start: 36812,
end: 37400,
confidence: 0.90331,
speaker: "A",
},
],
},
{
confidence: 0.92182406779661,
end: 56142,
speaker: "B",
start: 38970,
text: "Well, there's a couple of things. The season has been pretty dry already. And then the fact that we're getting hit in the US. Is because there's a couple of weather systems that are essentially channeling the smoke from those Canadian wildfires through Pennsylvania into the Mid Atlantic and the Northeast and kind of just dropping the smoke there.",
words: [
{
text: "Well,",
start: 38970,
end: 39334,
confidence: 0.98456,
speaker: "B",
},
{
text: "there's",
start: 39372,
end: 39538,
confidence: 0.99997,
speaker: "B",
},
{
text: "a",
start: 39554,
end: 39686,
confidence: 0.97,
speaker: "B",
},
{
text: "couple",
start: 39708,
end: 39846,
confidence: 1.0,
speaker: "B",
},
{
text: "of",
start: 39868,
end: 40006,
confidence: 0.99,
speaker: "B",
},
{
text: "things.",
start: 40028,
end: 40694,
confidence: 1.0,
speaker: "B",
},
{
text: "The",
start: 40892,
end: 41302,
confidence: 1.0,
speaker: "B",
},
{
text: "season",
start: 41356,
end: 41634,
confidence: 0.99996,
speaker: "B",
},
{
text: "has",
start: 41682,
end: 41846,
confidence: 0.99998,
speaker: "B",
},
{
text: "been",
start: 41868,
end: 42006,
confidence: 0.99999,
speaker: "B",
},
{
text: "pretty",
start: 42028,
end: 42130,
confidence: 1.0,
speaker: "B",
},
{
text: "dry",
start: 42140,
end: 42374,
confidence: 0.76633,
speaker: "B",
},
{
text: "already.",
start: 42422,
end: 42922,
confidence: 0.99996,
speaker: "B",
},
{
text: "And",
start: 43056,
end: 43306,
confidence: 1.0,
speaker: "B",
},
{
text: "then",
start: 43328,
end: 43610,
confidence: 0.56978,
speaker: "B",
},
{
text: "the",
start: 43680,
end: 43914,
confidence: 0.6,
speaker: "B",
},
{
text: "fact",
start: 43952,
end: 44106,
confidence: 0.99998,
speaker: "B",
},
{
text: "that",
start: 44128,
end: 44266,
confidence: 0.99706,
speaker: "B",
},
{
text: "we're",
start: 44288,
end: 44486,
confidence: 0.92122,
speaker: "B",
},
{
text: "getting",
start: 44518,
end: 44714,
confidence: 0.99998,
speaker: "B",
},
{
text: "hit",
start: 44752,
end: 45002,
confidence: 0.51955,
speaker: "B",
},
{
text: "in",
start: 45056,
end: 45178,
confidence: 0.99999,
speaker: "B",
},
{
text: "the",
start: 45184,
end: 45306,
confidence: 1.0,
speaker: "B",
},
{
text: "US.",
start: 45328,
end: 45898,
confidence: 0.87,
speaker: "B",
},
{
text: "Is",
start: 46064,
end: 46442,
confidence: 0.55822,
speaker: "B",
},
{
text: "because",
start: 46496,
end: 46714,
confidence: 0.99996,
speaker: "B",
},
{
text: "there's",
start: 46752,
end: 46998,
confidence: 0.9991,
speaker: "B",
},
{
text: "a",
start: 47014,
end: 47098,
confidence: 1.0,
speaker: "B",
},
{
text: "couple",
start: 47104,
end: 47226,
confidence: 0.99361,
speaker: "B",
},
{
text: "of",
start: 47248,
end: 47338,
confidence: 0.86,
speaker: "B",
},
{
text: "weather",
start: 47344,
end: 47606,
confidence: 0.99983,
speaker: "B",
},
{
text: "systems",
start: 47638,
end: 47958,
confidence: 0.99999,
speaker: "B",
},
{
text: "that",
start: 47974,
end: 48106,
confidence: 1.0,
speaker: "B",
},
{
text: "are",
start: 48128,
end: 48218,
confidence: 0.99996,
speaker: "B",
},
{
text: "essentially",
start: 48224,
end: 48502,
confidence: 0.66886,
speaker: "B",
},
{
text: "channeling",
start: 48566,
end: 48998,
confidence: 0.9995,
speaker: "B",
},
{
text: "the",
start: 49014,
end: 49146,
confidence: 1.0,
speaker: "B",
},
{
text: "smoke",
start: 49168,
end: 49398,
confidence: 0.99997,
speaker: "B",
},
{
text: "from",
start: 49414,
end: 49546,
confidence: 0.99937,
speaker: "B",
},
{
text: "those",
start: 49568,
end: 49706,
confidence: 0.99991,
speaker: "B",
},
{
text: "Canadian",
start: 49728,
end: 50086,
confidence: 1.0,
speaker: "B",
},
{
text: "wildfires",
start: 50118,
end: 51062,
confidence: 0.49043,
speaker: "B",
},
{
text: "through",
start: 51206,
end: 51610,
confidence: 0.99999,
speaker: "B",
},
{
text: "Pennsylvania",
start: 51680,
end: 52326,
confidence: 0.99493,
speaker: "B",
},
{
text: "into",
start: 52358,
end: 52506,
confidence: 0.99998,
speaker: "B",
},
{
text: "the",
start: 52528,
end: 52618,
confidence: 1.0,
speaker: "B",
},
{
text: "Mid",
start: 52624,
end: 52758,
confidence: 1.0,
speaker: "B",
},
{
text: "Atlantic",
start: 52784,
end: 53178,
confidence: 0.68127,
speaker: "B",
},
{
text: "and",
start: 53194,
end: 53278,
confidence: 0.71,
speaker: "B",
},
{
text: "the",
start: 53284,
end: 53406,
confidence: 1.0,
speaker: "B",
},
{
text: "Northeast",
start: 53428,
end: 53866,
confidence: 0.98714,
speaker: "B",
},
{
text: "and",
start: 53898,
end: 54190,
confidence: 0.99,
speaker: "B",
},
{
text: "kind",
start: 54260,
end: 54398,
confidence: 0.99994,
speaker: "B",
},
{
text: "of",
start: 54404,
end: 54574,
confidence: 0.53,
speaker: "B",
},
{
text: "just",
start: 54612,
end: 54766,
confidence: 0.99999,
speaker: "B",
},
{
text: "dropping",
start: 54788,
end: 55146,
confidence: 0.74603,
speaker: "B",
},
{
text: "the",
start: 55178,
end: 55278,
confidence: 1.0,
speaker: "B",
},
{
text: "smoke",
start: 55284,
end: 55594,
confidence: 0.99134,
speaker: "B",
},
{
text: "there.",
start: 55642,
end: 56142,
confidence: 0.99999,
speaker: "B",
},
],
},
{
confidence: 0.9296276470588234,
end: 61070,
speaker: "A",
start: 56276,
text: "So what is it in this haze that makes it harmful? And I'm assuming it is harmful.",
words: [
{
text: "So",
start: 56276,
end: 56574,
confidence: 0.57369,
speaker: "A",
},
{
text: "what",
start: 56612,
end: 56814,
confidence: 0.98951,
speaker: "A",
},
{
text: "is",
start: 56852,
end: 56958,
confidence: 0.99994,
speaker: "A",
},
{
text: "it",
start: 56964,
end: 57086,
confidence: 0.98926,
speaker: "A",
},
{
text: "in",
start: 57108,
end: 57246,
confidence: 0.86342,
speaker: "A",
},
{
text: "this",
start: 57268,
end: 57454,
confidence: 1.0,
speaker: "A",
},
{
text: "haze",
start: 57492,
end: 57866,
confidence: 0.64143,
speaker: "A",
},
{
text: "that",
start: 57898,
end: 58094,
confidence: 1.0,
speaker: "A",
},
{
text: "makes",
start: 58132,
end: 58334,
confidence: 0.99999,
speaker: "A",
},
{
text: "it",
start: 58372,
end: 58718,
confidence: 0.88877,
speaker: "A",
},
{
text: "harmful?",
start: 58804,
end: 59274,
confidence: 0.99998,
speaker: "A",
},
{
text: "And",
start: 59322,
end: 59438,
confidence: 1.0,
speaker: "A",
},
{
text: "I'm",
start: 59444,
end: 59626,
confidence: 0.99865,
speaker: "A",
},
{
text: "assuming",
start: 59658,
end: 59978,
confidence: 0.99992,
speaker: "A",
},
{
text: "it",
start: 59994,
end: 60078,
confidence: 1.0,
speaker: "A",
},
{
text: "is",
start: 60084,
end: 60254,
confidence: 0.88077,
speaker: "A",
},
{
text: "harmful.",
start: 60292,
end: 61070,
confidence: 0.97834,
speaker: "A",
},
],
},
{
confidence: 0.9549970909090907,
end: 82950,
speaker: "B",
start: 62290,
text: "It is. The levels outside right now in Baltimore are considered unhealthy. And most of that is due to what's called particulate matter, which are tiny particles, microscopic smaller than the width of your hair that can get into your lungs and impact your respiratory system, your cardiovascular system, and even your neurological your brain.",
words: [
{
text: "It",
start: 62290,
end: 62606,
confidence: 0.76898,
speaker: "B",
},
{
text: "is.",
start: 62628,
end: 63150,
confidence: 0.99647,
speaker: "B",
},
{
text: "The",
start: 63300,
end: 63566,
confidence: 1.0,
speaker: "B",
},
{
text: "levels",
start: 63588,
end: 64042,
confidence: 0.99769,
speaker: "B",
},
{
text: "outside",
start: 64106,
end: 64490,
confidence: 0.99999,
speaker: "B",
},
{
text: "right",
start: 64580,
end: 64786,
confidence: 0.99999,
speaker: "B",
},
{
text: "now",
start: 64808,
end: 64946,
confidence: 1.0,
speaker: "B",
},
{
text: "in",
start: 64968,
end: 65058,
confidence: 0.99994,
speaker: "B",
},
{
text: "Baltimore",
start: 65064,
end: 65534,
confidence: 0.56902,
speaker: "B",
},
{
text: "are",
start: 65582,
end: 65746,
confidence: 0.99996,
speaker: "B",
},
{
text: "considered",
start: 65768,
end: 66046,
confidence: 0.99992,
speaker: "B",
},
{
text: "unhealthy.",
start: 66078,
end: 67010,
confidence: 0.92699,
speaker: "B",
},
{
text: "And",
start: 67750,
end: 68114,
confidence: 0.96,
speaker: "B",
},
{
text: "most",
start: 68152,
end: 68306,
confidence: 0.99998,
speaker: "B",
},
{
text: "of",
start: 68328,
end: 68466,
confidence: 0.71,
speaker: "B",
},
{
text: "that",
start: 68488,
end: 68626,
confidence: 0.99995,
speaker: "B",
},
{
text: "is",
start: 68648,
end: 68834,
confidence: 1.0,
speaker: "B",
},
{
text: "due",
start: 68872,
end: 69038,
confidence: 0.99999,
speaker: "B",
},
{
text: "to",
start: 69054,
end: 69282,
confidence: 1.0,
speaker: "B",
},
{
text: "what's",
start: 69336,
end: 69566,
confidence: 0.99943,
speaker: "B",
},
{
text: "called",
start: 69598,
end: 69794,
confidence: 1.0,
speaker: "B",
},
{
text: "particulate",
start: 69832,
end: 70238,
confidence: 0.99076,
speaker: "B",
},
{
text: "matter,",
start: 70254,
end: 70482,
confidence: 0.99998,
speaker: "B",
},
{
text: "which",
start: 70536,
end: 70706,
confidence: 1.0,
speaker: "B",
},
{
text: "are",
start: 70728,
end: 70866,
confidence: 0.99999,
speaker: "B",
},
{
text: "tiny",
start: 70888,
end: 71166,
confidence: 0.99994,
speaker: "B",
},
{
text: "particles,",
start: 71198,
end: 71902,
confidence: 0.9992,
speaker: "B",
},
{
text: "microscopic",
start: 72046,
end: 72894,
confidence: 0.63173,
speaker: "B",
},
{
text: "smaller",
start: 72942,
end: 73246,
confidence: 0.99984,
speaker: "B",
},
{
text: "than",
start: 73278,
end: 73426,
confidence: 0.99999,
speaker: "B",
},
{
text: "the",
start: 73448,
end: 73538,
confidence: 1.0,
speaker: "B",
},
{
text: "width",
start: 73544,
end: 73726,
confidence: 0.99994,
speaker: "B",
},
{
text: "of",
start: 73758,
end: 74002,
confidence: 0.97,
speaker: "B",
},
{
text: "your",
start: 74056,
end: 74226,
confidence: 0.99999,
speaker: "B",
},
{
text: "hair",
start: 74248,
end: 75002,
confidence: 0.85775,
speaker: "B",
},
{
text: "that",
start: 75166,
end: 75542,
confidence: 0.9669,
speaker: "B",
},
{
text: "can",
start: 75596,
end: 75766,
confidence: 1.0,
speaker: "B",
},
{
text: "get",
start: 75788,
end: 75926,
confidence: 0.99999,
speaker: "B",
},
{
text: "into",
start: 75948,
end: 76086,
confidence: 0.99999,
speaker: "B",
},
{
text: "your",
start: 76108,
end: 76246,
confidence: 1.0,
speaker: "B",
},
{
text: "lungs",
start: 76268,
end: 76546,
confidence: 0.86865,
speaker: "B",
},
{
text: "and",
start: 76578,
end: 76870,
confidence: 0.99,
speaker: "B",
},
{
text: "impact",
start: 76940,
end: 77314,
confidence: 0.99879,
speaker: "B",
},
{
text: "your",
start: 77362,
end: 77622,
confidence: 1.0,
speaker: "B",
},
{
text: "respiratory",
start: 77676,
end: 78226,
confidence: 0.99164,
speaker: "B",
},
{
text: "system,",
start: 78258,
end: 78454,
confidence: 1.0,
speaker: "B",
},
{
text: "your",
start: 78492,
end: 78646,
confidence: 0.99997,
speaker: "B",
},
{
text: "cardiovascular",
start: 78668,
end: 79522,
confidence: 0.99909,
speaker: "B",
},
{
text: "system,",
start: 79586,
end: 80198,
confidence: 0.99999,
speaker: "B",
},
{
text: "and",
start: 80364,
end: 80646,
confidence: 1.0,
speaker: "B",
},
{
text: "even",
start: 80668,
end: 81046,
confidence: 0.60772,
speaker: "B",
},
{
text: "your",
start: 81148,
end: 81414,
confidence: 0.9985,
speaker: "B",
},
{
text: "neurological",
start: 81452,
end: 82034,
confidence: 0.939,
speaker: "B",
},
{
text: "your",
start: 82082,
end: 82246,
confidence: 0.78769,
speaker: "B",
},
{
text: "brain.",
start: 82268,
end: 82950,
confidence: 0.99951,
speaker: "B",
},
],
},
],
}
| Key | Type | Description |
|---|---|---|
utterances | array | A turn-by-turn temporal sequence of the transcript, where the i-th element is an object containing information about the i-th utterance in the audio file. |
utterances[i].confidence | number | A score between 0 and 1 indicating the model’s confidence in the accuracy of the transcribed text for this utterance. |
utterances[i].end | number | The ending time, in milliseconds, of the utterance in the audio file. |
utterances[i].speaker | string | The speaker of this utterance, where each speaker is assigned a sequential capital letter. For example, “A” for Speaker A, “B” for Speaker B, and so on. |
utterances[i].start | number | The starting time, in milliseconds, of the utterance in the audio file. |
utterances[i].text | string | The transcript for this utterance. |
utterances[i].words | array | A sequential array for the words in the transcript, where the j-th element is an object containing information about the j-th word in the utterance. |
utterances[i].words[j].text | string | The text of the j-th word in the i-th utterance. |
utterances[i].words[j].start | number | The starting time for when the j-th word is spoken in the i-th utterance, in milliseconds. |
utterances[i].words[j].end | number | The ending time for when the j-th word is spoken in the i-th utterance, in milliseconds. |
utterances[i].words[j].confidence | number | The confidence score for the transcript of the j-th word in the i-th utterance. |
utterances[i].words[j].speaker | string | The speaker who uttered the j-th word in the i-th utterance. |
Identify speakers by name
Speaker Diarization assigns generic labels like “Speaker A” and “Speaker B” to each speaker. If you want to replace these labels with actual names or roles, you can use Speaker Identification to transform your transcript. Before Speaker Identification:Speaker A: Good morning, and welcome to the show.
Speaker B: Thanks for having me.
Michel Martin: Good morning, and welcome to the show.
Peter DeCarlo: Thanks for having me.
- Python
- JavaScript
maxLines=30
import requests
import time
base_url = "https://api.assemblyai.com"
headers = {
"authorization": "<YOUR_API_KEY>"
}
audio_url = "https://assembly.ai/wildfires.mp3"
# Configure transcript with speaker diarization and speaker identification
data = {
"audio_url": audio_url,
"speech_models": ["universal-3-pro", "universal-2"],
"language_detection": True,
"speaker_labels": True,
"speech_understanding": {
"request": {
"speaker_identification": {
"speaker_type": "name",
"known_values": ["Michel Martin", "Peter DeCarlo"]
}
}
}
}
# Submit the transcription request
response = requests.post(base_url + "/v2/transcript", headers=headers, json=data)
transcript_id = response.json()["id"]
polling_endpoint = base_url + f"/v2/transcript/{transcript_id}"
# Poll for transcription results
while True:
transcript = requests.get(polling_endpoint, headers=headers).json()
if transcript["status"] == "completed":
break
elif transcript["status"] == "error":
raise RuntimeError(f"Transcription failed: {transcript['error']}")
else:
time.sleep(3)
# Print utterances with identified speaker names
for utterance in transcript["utterances"]:
print(f"{utterance['speaker']}: {utterance['text']}")
maxLines=30
const baseUrl = "https://api.assemblyai.com";
const headers = {
authorization: "<YOUR_API_KEY>",
"content-type": "application/json",
};
const audioUrl = "https://assembly.ai/wildfires.mp3";
// Configure transcript with speaker diarization and speaker identification
const data = {
audio_url: audioUrl,
speech_models: ["universal-3-pro", "universal-2"],
language_detection: true,
speaker_labels: true,
speech_understanding: {
request: {
speaker_identification: {
speaker_type: "name",
known_values: ["Michel Martin", "Peter DeCarlo"],
},
},
},
};
async function main() {
// Submit the transcription request
const response = await fetch(`${baseUrl}/v2/transcript`, {
method: "POST",
headers: headers,
body: JSON.stringify(data),
});
if (!response.ok) throw new Error(`Error: ${response.status}`);
const { id: transcriptId } = await response.json();
const pollingEndpoint = `${baseUrl}/v2/transcript/${transcriptId}`;
// Poll for transcription results
while (true) {
const pollingResponse = await fetch(pollingEndpoint, { headers });
if (!pollingResponse.ok) throw new Error(`Error: ${pollingResponse.status}`);
const transcript = await pollingResponse.json();
if (transcript.status === "completed") {
// Print utterances with identified speaker names
for (const utterance of transcript.utterances) {
console.log(`${utterance.speaker}: ${utterance.text}`);
}
break;
} else if (transcript.status === "error") {
throw new Error(`Transcription failed: ${transcript.error}`);
} else {
await new Promise((resolve) => setTimeout(resolve, 3000));
}
}
}
main().catch(console.error);
Best practices for accurate diarization
Follow these tips to get the best results from Speaker Diarization:- Ensure sufficient speech per speaker. Each speaker should speak for at least 30 seconds uninterrupted. The model may struggle to create separate clusters for speakers who only contribute short phrases like “Yeah”, “Right”, or “Sounds good”.
- Minimize cross-talk. Overlapping speech between speakers can reduce diarization accuracy. Where possible, ensure speakers take turns.
- Reduce background noise. Background noise, echoes, or playback of recorded audio during a conversation can interfere with speaker separation.
- Use
speaker_optionsinstead ofspeakers_expectedwhen uncertain. Only usespeakers_expectedwhen you are confident about the exact number of speakers. If this number is incorrect, the model may produce random splits of single-speaker segments or merge multiple speakers into one. It’s generally recommended to usemin_speakers_expectedand setmax_speakers_expectedslightly higher (e.g.,min_speakers_expected+ 2) to allow flexibility. - Avoid setting
max_speakers_expectedtoo high. Setting the maximum too high may reduce accuracy, causing sentences from the same speaker to be split across multiple speaker labels. - Be aware of speaker similarity. If speakers sound similar, the model may have difficulty distinguishing between them.
Frequently asked questions
How many speakers can the model handle?
How many speakers can the model handle?
The default upper limit on the number of speakers depends on the audio duration:
- 0–2 minutes: no max speaker limit
- 2–10 minutes: max 10 speakers
- 10+ minutes: max 30 speakers
speaker_options
to set a range of possible speakers.How accurate is the Speaker Diarization model?
How accurate is the Speaker Diarization model?
The accuracy of the Speaker Diarization model depends on several factors,
including the quality of the audio, the number of speakers, and the length of
the audio file. See the best
practices section above for tips on
improving accuracy.