Xin Zhang commited on
Commit
fc1629b
·
1 Parent(s): 83dbef6

[fix]: whisper_full_with_state: input is too short - 990 ms < 1000 ms. consider padding the input audio with silence.

Browse files
Files changed (1) hide show
  1. transcribe/serve.py +17 -7
transcribe/serve.py CHANGED
@@ -92,7 +92,7 @@ class WhisperTranscriptionService:
92
  self.full_segments_queue.appendleft(audio_array) # 根据时间是否满足三秒长度 来整合音频块
93
  self.frames_np_start_timestamp = time.time()
94
  self.frames_np = np.array([], dtype=np.float32)
95
-
96
  # 音频结束信号的时候 整合当前缓冲区
97
  # START -- END -- START -- END 通常
98
  # START -- END -- END end块带有音频信息的通常是4096内断的一个短音
@@ -105,7 +105,7 @@ class WhisperTranscriptionService:
105
  self.frames_np = np.array([], dtype=np.float32)
106
  else:
107
  logger.debug(f"🥳 当前时间与上一句的时间差: {time_diff:.2f}s,继续保留在缓冲区")
108
-
109
  except queue.Empty:
110
  pass
111
 
@@ -114,7 +114,7 @@ class WhisperTranscriptionService:
114
  frame_epoch = 1
115
 
116
  while not self._stop.is_set():
117
-
118
  if len(self.frames_np) ==0:
119
  time.sleep(0.1)
120
  continue
@@ -126,11 +126,21 @@ class WhisperTranscriptionService:
126
  else:
127
  audio_buffer = self.frames_np[:int(frame_epoch * 1.5 * self.sample_rate)].copy()# 获取 1.5s * epoch 个音频长度
128
  partial = True
129
-
130
  if len(audio_buffer) < int(self.sample_rate):
131
- silence_audio = np.zeros(self.sample_rate, dtype=np.float32)
132
- silence_audio[-len(audio_buffer):] = audio_buffer
 
 
 
 
 
133
  audio_buffer = silence_audio
 
 
 
 
 
134
 
135
  logger.debug(f"audio buffer size: {len(audio_buffer) / self.sample_rate:.2f}s")
136
  meta_item = self._transcribe_audio(audio_buffer)
@@ -177,7 +187,7 @@ class WhisperTranscriptionService:
177
 
178
  result = self.translate_pipe.translate(text, self.source_language, self.target_language)
179
  translated_text = result.translate_content
180
-
181
  log_block("🐧 Translation out ", f"{translated_text}")
182
  return translated_text
183
 
 
92
  self.full_segments_queue.appendleft(audio_array) # 根据时间是否满足三秒长度 来整合音频块
93
  self.frames_np_start_timestamp = time.time()
94
  self.frames_np = np.array([], dtype=np.float32)
95
+
96
  # 音频结束信号的时候 整合当前缓冲区
97
  # START -- END -- START -- END 通常
98
  # START -- END -- END end块带有音频信息的通常是4096内断的一个短音
 
105
  self.frames_np = np.array([], dtype=np.float32)
106
  else:
107
  logger.debug(f"🥳 当前时间与上一句的时间差: {time_diff:.2f}s,继续保留在缓冲区")
108
+
109
  except queue.Empty:
110
  pass
111
 
 
114
  frame_epoch = 1
115
 
116
  while not self._stop.is_set():
117
+
118
  if len(self.frames_np) ==0:
119
  time.sleep(0.1)
120
  continue
 
126
  else:
127
  audio_buffer = self.frames_np[:int(frame_epoch * 1.5 * self.sample_rate)].copy()# 获取 1.5s * epoch 个音频长度
128
  partial = True
129
+
130
  if len(audio_buffer) < int(self.sample_rate):
131
+ # Add a small buffer (e.g., 10ms worth of samples) to be safe
132
+ padding_samples = int(self.sample_rate * 0.01) # e.g., 160 samples for 10ms at 16kHz
133
+ target_length = self.sample_rate + padding_samples
134
+ silence_audio = np.zeros(target_length, dtype=np.float32)
135
+ # Ensure we don't try to copy more data than exists if audio_buffer is very short
136
+ copy_length = min(len(audio_buffer), target_length)
137
+ silence_audio[-copy_length:] = audio_buffer[-copy_length:] # Copy from the end of audio_buffer
138
  audio_buffer = silence_audio
139
+ elif len(audio_buffer) > self.sample_rate * config.MAX_SPEECH_DURATION_S:
140
+ # If buffer is too long even without padding, truncate it (optional, depends on desired behavior)
141
+ # This case might already be handled elsewhere, but good to consider
142
+ audio_buffer = audio_buffer[:int(self.sample_rate * config.MAX_SPEECH_DURATION_S)]
143
+
144
 
145
  logger.debug(f"audio buffer size: {len(audio_buffer) / self.sample_rate:.2f}s")
146
  meta_item = self._transcribe_audio(audio_buffer)
 
187
 
188
  result = self.translate_pipe.translate(text, self.source_language, self.target_language)
189
  translated_text = result.translate_content
190
+
191
  log_block("🐧 Translation out ", f"{translated_text}")
192
  return translated_text
193