No description
Find a file
2022-10-12 15:46:18 -06:00
examples rename library to whisper-rs 2022-10-09 20:48:00 -06:00
src add Send and Sync impls 2022-10-10 17:37:53 -06:00
sys update remote whisper.cpp to b2f1600aa380e3ec5dc0de6194e38f27245c2a6a 2022-10-12 15:35:55 -06:00
.gitignore ignore .idea 2022-10-12 15:46:18 -06:00
.gitmodules Initial commit 2022-10-09 20:17:31 -06:00
Cargo.toml bump version again 2022-10-10 17:51:45 -06:00
LICENSE add LICENSE and README.md 2022-10-09 20:46:14 -06:00
README.md update README.md 2022-10-12 15:45:48 -06:00

whisper-rs

Rust bindings to whisper.cpp

Usage

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(DecodeStrategy::Greedy { n_past: 0 });

    // 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
    ctx.full(params, &audio_data[..])
        .expect("failed to run model");

    // fetch the results
    let num_segments = ctx.full_n_segments();
    for i in 0..num_segments {
        let segment = ctx.full_get_segment_text(i).expect("failed to get segment");
        let start_timestamp = ctx.full_get_segment_t0(i);
        let end_timestamp = ctx.full_get_segment_t1(i);
        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.

Troubleshooting

  • I get an error about a lot of undefined symbols at compile time!
    • These symbols might be part of the C++ standard library.
      • Try linking against it with the -Clink-args=-lstdc++ compiler flag:
      • RUSTFLAGS="-Clink-args=-lstdc++" cargo build
  • Windows/macOS/Android aren't working!
    • I don't have a way to test these platforms, so I can't really help you.
      • If you can get it working, please open a PR!

License

Unlicense

tl;dr: public domain