From f7e6fff9602c0ce0c276d68372ad624c72585a0f Mon Sep 17 00:00:00 2001 From: Jeronymous Date: Fri, 1 Mar 2024 09:44:46 +0100 Subject: [PATCH] Add speech activity segments in the output --- whisper_timestamped/transcribe.py | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/whisper_timestamped/transcribe.py b/whisper_timestamped/transcribe.py index a88d677..3b7fd61 100644 --- a/whisper_timestamped/transcribe.py +++ b/whisper_timestamped/transcribe.py @@ -3,7 +3,7 @@ __author__ = "Jérôme Louradour" __credits__ = ["Jérôme Louradour"] __license__ = "GPLv3" -__version__ = "1.15.0" +__version__ = "1.15.1" # Set some environment variables import os @@ -279,8 +279,10 @@ def transcribe_timestamped( if vad: audio = get_audio_tensor(audio) - audio, convert_timestamps = remove_non_speech(audio, method=vad, sample_rate=SAMPLE_RATE, plot=plot_word_alignment) - + audio, vad_segments, convert_timestamps = remove_non_speech(audio, method=vad, sample_rate=SAMPLE_RATE, plot=plot_word_alignment) + else: + vad_segments = None + global num_alignment_for_plot num_alignment_for_plot = 0 @@ -335,6 +337,9 @@ def transcribe_timestamped( else: segment["start"], segment["end"] = convert_timestamps(segment["start"], segment["end"]) + if vad_segments is not None: + transcription["speech_activity"] = [{"start":s, "end":e} for (s,e) in vad_segments] + return transcription def _transcribe_timestamped_efficient( @@ -2116,7 +2121,7 @@ def remove_non_speech(audio, if not use_sample: segments = [(float(s)/sample_rate, float(e)/sample_rate) for s,e in segments] - return audio_speech, lambda t, t2 = None: do_convert_timestamps(segments, t, t2) + return audio_speech, segments, lambda t, t2 = None: do_convert_timestamps(segments, t, t2) def do_convert_timestamps(segments, t, t2 = None): """ @@ -3132,6 +3137,7 @@ def filtered_keys(result, keys = [ "end", "confidence", "language_probs", + "speech_activity", ]): if isinstance(result, dict): return {k: (filtered_keys(v, keys) if k not in ["language_probs"] else v) for k, v in result.items() if k in keys}