Skip to content

Commit

Permalink
Merge pull request #271 from Wordcab/270-improve-diarization
Browse files Browse the repository at this point in the history
Adjust VAD speech padding for diarizer, add additional logic to speak…
  • Loading branch information
aleksandr-smechov authored Oct 10, 2023
2 parents 1df1a86 + 1e1b40f commit cd08be2
Show file tree
Hide file tree
Showing 2 changed files with 68 additions and 13 deletions.
79 changes: 67 additions & 12 deletions src/wordcab_transcribe/services/post_processing_service.py
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,26 @@ def segments_speaker_mapping(
Returns:
List[dict]: List of sentences with speaker mapping.
"""

def _assign_speaker(
mapping: list,
seg_index: int,
split: bool,
current_speaker: str,
current_split_len: int,
):
"""Assign speaker to the segment."""
if split and len(mapping) > 1:
last_split_len = len(mapping[seg_index - 1].text)
if last_split_len > current_split_len:
current_speaker = mapping[seg_index - 1].speaker
elif last_split_len < current_split_len:
mapping[seg_index - 1].speaker = current_speaker
return current_speaker

threshold = 0.3
turn_idx = 0
was_split = False
_, end, speaker = speaker_timestamps[turn_idx]

segment_index = 0
Expand All @@ -131,59 +150,87 @@ def segments_speaker_mapping(
segment.end,
segment.text,
)

while segment_start > float(end) or abs(segment_start - float(end)) < 0.3:
while (
segment_start > float(end)
or abs(segment_start - float(end)) < threshold
):
turn_idx += 1
turn_idx = min(turn_idx, len(speaker_timestamps) - 1)
_, end, speaker = speaker_timestamps[turn_idx]
if turn_idx == len(speaker_timestamps) - 1:
end = segment_end
break

if segment_end > float(end):
if segment_end > float(end) and abs(segment_end - float(end)) > threshold:
words = segment.words

word_index = next(
(
i
for i, word in enumerate(words)
if word.start > float(end) or abs(word.start - float(end)) < 0.3
if word.start > float(end)
or abs(word.start - float(end)) < threshold
),
None,
)

if word_index is not None:
_splitted_segment = segment_text.split()
_split_segment = segment_text.split()

if word_index > 0:
text = " ".join(_split_segment[:word_index])
speaker = _assign_speaker(
segment_speaker_mapping,
segment_index,
was_split,
speaker,
len(text),
)

_segment_to_add = Utterance(
start=words[0].start,
end=words[word_index - 1].end,
text=" ".join(_splitted_segment[:word_index]),
text=text,
speaker=speaker,
words=words[:word_index],
)

else:
text = _split_segment[0]
speaker = _assign_speaker(
segment_speaker_mapping,
segment_index,
was_split,
speaker,
len(text),
)

_segment_to_add = Utterance(
start=words[0].start,
end=words[0].end,
text=_splitted_segment[0],
text=_split_segment[0],
speaker=speaker,
words=words[:1],
)

segment_speaker_mapping.append(_segment_to_add)
transcript_segments.insert(
segment_index + 1,
Utterance(
start=words[word_index].start,
end=segment_end,
text=" ".join(_splitted_segment[word_index:]),
text=" ".join(_split_segment[word_index:]),
words=words[word_index:],
),
)
was_split = True
else:
speaker = _assign_speaker(
segment_speaker_mapping,
segment_index,
was_split,
speaker,
len(segment_text),
)
was_split = False

segment_speaker_mapping.append(
Utterance(
start=segment_start,
Expand All @@ -194,6 +241,15 @@ def segments_speaker_mapping(
)
)
else:
speaker = _assign_speaker(
segment_speaker_mapping,
segment_index,
was_split,
speaker,
len(segment_text),
)
was_split = False

segment_speaker_mapping.append(
Utterance(
start=segment_start,
Expand All @@ -203,7 +259,6 @@ def segments_speaker_mapping(
words=segment.words,
)
)

segment_index += 1

return segment_speaker_mapping
Expand Down
2 changes: 1 addition & 1 deletion src/wordcab_transcribe/services/vad_service.py
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ def __init__(self) -> None:
max_speech_duration_s=30,
min_silence_duration_ms=100,
window_size_samples=512,
speech_pad_ms=30,
speech_pad_ms=400,
)

def __call__(
Expand Down

0 comments on commit cd08be2

Please sign in to comment.