Crates.io | whisper-rs-2 |
lib.rs | whisper-rs-2 |
version | 0.2.1 |
source | src |
created_at | 2022-11-01 23:10:19.108752 |
updated_at | 2022-11-03 01:51:28.627138 |
description | Rust bindings for whisper.cpp |
homepage | |
repository | https://github.com/jafri/whisper-rs |
max_upload_size | |
id | 703127 |
size | 43,091 |
Rust bindings to whisper.cpp
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.
-Clink-args=-lstdc++
compiler flag:RUSTFLAGS="-Clink-args=-lstdc++" cargo build
WHISPER_DONT_GENERATE_BINDINGS
environment variable.
This skips attempting to build the bindings whatsoever and copies the existing ones. They may be out of date,
but it's better than nothing.
WHISPER_DONT_GENERATE_BINDINGS=1 cargo build
tl;dr: public domain