summaryrefslogtreecommitdiff
path: root/candle-examples/examples/whisper-microphone/main.rs
diff options
context:
space:
mode:
Diffstat (limited to 'candle-examples/examples/whisper-microphone/main.rs')
-rw-r--r--candle-examples/examples/whisper-microphone/main.rs20
1 files changed, 17 insertions, 3 deletions
diff --git a/candle-examples/examples/whisper-microphone/main.rs b/candle-examples/examples/whisper-microphone/main.rs
index 5165da1c..373c40e2 100644
--- a/candle-examples/examples/whisper-microphone/main.rs
+++ b/candle-examples/examples/whisper-microphone/main.rs
@@ -624,13 +624,27 @@ pub fn main() -> Result<()> {
continue;
}
let mut resampled_pcm = vec![];
- for buffered_pcm in buffered_pcm.chunks(1024) {
+ // resample the audio, one chunk of 1024 samples at a time.
+ // in case the audio input failed to produce an exact multiple of 1024 samples,
+ // process the remainder on the next iteration of the loop.
+ let full_chunks = buffered_pcm.len() / 1024;
+ let remainder = buffered_pcm.len() % 1024;
+ for chunk in 0..full_chunks {
+ let buffered_pcm = &buffered_pcm[chunk * 1024..(chunk + 1) * 1024];
let pcm = resampler.process(&[&buffered_pcm], None)?;
- resampled_pcm.extend_from_slice(&pcm[0])
+ resampled_pcm.extend_from_slice(&pcm[0]);
}
let pcm = resampled_pcm;
println!("{} {}", buffered_pcm.len(), pcm.len());
- buffered_pcm.clear();
+ if remainder == 0 {
+ buffered_pcm.clear();
+ } else {
+ // efficiently copy the remainder to the beginning of the `buffered_pcm` buffer and
+ // truncate it. That's more efficient then allocating a new vector and copying into it
+ println!("audio device produced partial chunk with {remainder} samples; processing the remainder on the next iteration of the loop");
+ buffered_pcm.copy_within(full_chunks * 1024.., 0);
+ buffered_pcm.truncate(remainder);
+ }
let mel = audio::pcm_to_mel(&config, &pcm, &mel_filters);
let mel_len = mel.len();
let mel = Tensor::from_vec(