whisper-rs

Rust bindings to whisper.cpp

Usage

```rust use whisper_rs::{WhisperContext, FullParams, SamplingStrategy};

fn main() { // load a context and model let mut ctx = WhisperContext::new("path/to/model").expect("failed to load model");

// create a params object
let mut params = FullParams::new(SamplingStrategy::Greedy { best_of: 1 });

// assume we have a buffer of audio data
// here we'll make a fake one, floating point samples, 32 bit, 16KHz, mono
let audio_data = vec![0_f32; 16000 * 2];

// now we can run the model
let state = ctx.create_state().expect("failed to create state");
ctx.full(&state, params, &audio_data[..])
    .expect("failed to run model");

// fetch the results
let num_segments = ctx
    .full_n_segments(&state)
    .expect("failed to get number of segments");
for i in 0..num_segments {
    let segment = ctx
        .full_get_segment_text(&state, i)
        .expect("failed to get segment");
    let start_timestamp = ctx
        .full_get_segment_t0(&state, i)
        .expect("failed to get segment start timestamp");
    let end_timestamp = ctx
        .full_get_segment_t1(&state, i)
        .expect("failed to get segment end timestamp");
    println!("[{} - {}]: {}", start_timestamp, end_timestamp, segment);
}

} ```

See examples/basic_use.rs for more details.

Lower level bindings are exposed if needed, but the above should be enough for most use cases. See the docs: https://docs.rs/whisper-rs/ for more details.

Building

See BUILDING.md for instructions for building whisper-rs on Windows and OSX M1. Linux builds should just work out of the box.

Troubleshooting

License

Unlicense

tl;dr: public domain