#whisper #transcription #ai

rwhisper

A simple interface for Whisper transcription models in Rust

10 releases

0.3.5 Aug 28, 2024
0.3.4 Aug 24, 2024
0.2.1 Feb 28, 2024
0.1.2 Dec 21, 2023

#471 in Audio

Download history 150/week @ 2024-09-18 126/week @ 2024-09-25 85/week @ 2024-10-02 36/week @ 2024-10-09 59/week @ 2024-10-16 36/week @ 2024-10-23 37/week @ 2024-10-30 18/week @ 2024-11-06 31/week @ 2024-11-13 46/week @ 2024-11-20 44/week @ 2024-11-27 52/week @ 2024-12-04 77/week @ 2024-12-11 45/week @ 2024-12-18 15/week @ 2024-12-25 68/week @ 2025-01-01

215 downloads per month
Used in 3 crates (via kalosm-sound)

MIT/Apache

505KB
4.5K SLoC

rwhisper

A Rust wrapper for whisper

Usage

use futures_util::StreamExt;
use kalosm::sound::*;
use tokio::time::{Duration, Instant};

#[tokio::main]
async fn main() -> Result<(), anyhow::Error> {
    // Create a new small whisper model.
    let model = WhisperBuilder::default()
        .with_source(WhisperSource::SmallEn)
        .build()
        .await?;

    // Record audio from the microphone for 5 seconds.
    let audio = MicInput::default()
        .record_until(Instant::now() + Duration::from_secs(5))
        .await?;

    // Transcribe the audio.
    let mut text = model.transcribe(audio)?;

    // As the model transcribes the audio, print the text to the console.
    while let Some(text) = text.next().await {
        print!("{}", text.text());
    }

    Ok(())
}

Dependencies

~36–77MB
~1.5M SLoC