migrate state method into state object
This commit is contained in:
parent
0fe0a87a09
commit
ef4b9f0630
5 changed files with 539 additions and 581 deletions
|
|
@ -9,7 +9,7 @@ pub fn usage() -> Result<(), &'static str> {
|
|||
// load a context and model
|
||||
let ctx = WhisperContext::new("path/to/model").expect("failed to load model");
|
||||
// make a state
|
||||
let state = ctx.create_state().expect("failed to create state");
|
||||
let mut state = ctx.create_state().expect("failed to create state");
|
||||
|
||||
// create a params object
|
||||
// note that currently the only implemented strategy is Greedy, BeamSearch is a WIP
|
||||
|
|
@ -44,22 +44,23 @@ pub fn usage() -> Result<(), &'static str> {
|
|||
|
||||
// now we can run the model
|
||||
// note the key we use here is the one we created above
|
||||
ctx.full(&state, params, &audio_data[..])
|
||||
state
|
||||
.full(params, &audio_data[..])
|
||||
.expect("failed to run model");
|
||||
|
||||
// fetch the results
|
||||
let num_segments = ctx
|
||||
.full_n_segments(&state)
|
||||
let num_segments = state
|
||||
.full_n_segments()
|
||||
.expect("failed to get number of segments");
|
||||
for i in 0..num_segments {
|
||||
let segment = ctx
|
||||
.full_get_segment_text(&state, i)
|
||||
let segment = state
|
||||
.full_get_segment_text(i)
|
||||
.expect("failed to get segment");
|
||||
let start_timestamp = ctx
|
||||
.full_get_segment_t0(&state, i)
|
||||
let start_timestamp = state
|
||||
.full_get_segment_t0(i)
|
||||
.expect("failed to get segment start timestamp");
|
||||
let end_timestamp = ctx
|
||||
.full_get_segment_t1(&state, i)
|
||||
let end_timestamp = state
|
||||
.full_get_segment_t1(i)
|
||||
.expect("failed to get segment end timestamp");
|
||||
println!("[{} - {}]: {}", start_timestamp, end_timestamp, segment);
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue