mirror of
https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs.git
synced 2025-01-09 18:55:27 +00:00
aws_transcriber: expose lateness property
The default behavior for the transcriber is to output text buffers synchronized with the input stream, introducing a configurable latency. For use cases where synchronization is not crucial, but latency is, the lateness property can be used instead of or in combination with the latency property, in order to introduce a configurable offset with the input stream. Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-rs/-/merge_requests/534>
This commit is contained in:
parent
97e00df5a7
commit
bf24909703
1 changed files with 41 additions and 3 deletions
|
@ -115,12 +115,14 @@ static RUNTIME: Lazy<runtime::Runtime> = Lazy::new(|| {
|
||||||
});
|
});
|
||||||
|
|
||||||
const DEFAULT_LATENCY: gst::ClockTime = gst::ClockTime::from_seconds(8);
|
const DEFAULT_LATENCY: gst::ClockTime = gst::ClockTime::from_seconds(8);
|
||||||
|
const DEFAULT_LATENESS: gst::ClockTime = gst::ClockTime::from_seconds(0);
|
||||||
const DEFAULT_STABILITY: AwsTranscriberResultStability = AwsTranscriberResultStability::Low;
|
const DEFAULT_STABILITY: AwsTranscriberResultStability = AwsTranscriberResultStability::Low;
|
||||||
const GRANULARITY: gst::ClockTime = gst::ClockTime::from_mseconds(100);
|
const GRANULARITY: gst::ClockTime = gst::ClockTime::from_mseconds(100);
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
struct Settings {
|
struct Settings {
|
||||||
latency: gst::ClockTime,
|
latency: gst::ClockTime,
|
||||||
|
lateness: gst::ClockTime,
|
||||||
language_code: Option<String>,
|
language_code: Option<String>,
|
||||||
vocabulary: Option<String>,
|
vocabulary: Option<String>,
|
||||||
session_id: Option<String>,
|
session_id: Option<String>,
|
||||||
|
@ -131,6 +133,7 @@ impl Default for Settings {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
Self {
|
Self {
|
||||||
latency: DEFAULT_LATENCY,
|
latency: DEFAULT_LATENCY,
|
||||||
|
lateness: DEFAULT_LATENESS,
|
||||||
language_code: Some("en-US".to_string()),
|
language_code: Some("en-US".to_string()),
|
||||||
vocabulary: None,
|
vocabulary: None,
|
||||||
session_id: None,
|
session_id: None,
|
||||||
|
@ -370,11 +373,15 @@ impl Transcriber {
|
||||||
alternative: &TranscriptAlternative,
|
alternative: &TranscriptAlternative,
|
||||||
partial: bool,
|
partial: bool,
|
||||||
) {
|
) {
|
||||||
|
let lateness = self.settings.lock().unwrap().lateness;
|
||||||
|
|
||||||
for item in &alternative.items[state.partial_index..] {
|
for item in &alternative.items[state.partial_index..] {
|
||||||
let start_time =
|
let start_time =
|
||||||
gst::ClockTime::from_nseconds((item.start_time as f64 * 1_000_000_000.0) as u64);
|
gst::ClockTime::from_nseconds((item.start_time as f64 * 1_000_000_000.0) as u64)
|
||||||
|
+ lateness;
|
||||||
let end_time =
|
let end_time =
|
||||||
gst::ClockTime::from_nseconds((item.end_time as f64 * 1_000_000_000.0) as u64);
|
gst::ClockTime::from_nseconds((item.end_time as f64 * 1_000_000_000.0) as u64)
|
||||||
|
+ lateness;
|
||||||
|
|
||||||
if !item.stable {
|
if !item.stable {
|
||||||
break;
|
break;
|
||||||
|
@ -839,6 +846,18 @@ impl Transcriber {
|
||||||
|
|
||||||
let settings = self.settings.lock().unwrap();
|
let settings = self.settings.lock().unwrap();
|
||||||
|
|
||||||
|
if settings.latency + settings.lateness <= 2 * GRANULARITY {
|
||||||
|
gst_error!(
|
||||||
|
CAT,
|
||||||
|
obj: element,
|
||||||
|
"latency + lateness must be greater than 200 milliseconds"
|
||||||
|
);
|
||||||
|
return Err(error_msg!(
|
||||||
|
gst::LibraryError::Settings,
|
||||||
|
["latency + lateness must be greater than 200 milliseconds"]
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
||||||
gst_info!(CAT, obj: element, "Connecting ..");
|
gst_info!(CAT, obj: element, "Connecting ..");
|
||||||
|
|
||||||
let creds = {
|
let creds = {
|
||||||
|
@ -1059,11 +1078,20 @@ impl ObjectImpl for Transcriber {
|
||||||
"latency",
|
"latency",
|
||||||
"Latency",
|
"Latency",
|
||||||
"Amount of milliseconds to allow AWS transcribe",
|
"Amount of milliseconds to allow AWS transcribe",
|
||||||
2 * GRANULARITY.mseconds() as u32,
|
0,
|
||||||
std::u32::MAX,
|
std::u32::MAX,
|
||||||
DEFAULT_LATENCY.mseconds() as u32,
|
DEFAULT_LATENCY.mseconds() as u32,
|
||||||
glib::ParamFlags::READWRITE | gst::PARAM_FLAG_MUTABLE_READY,
|
glib::ParamFlags::READWRITE | gst::PARAM_FLAG_MUTABLE_READY,
|
||||||
),
|
),
|
||||||
|
glib::ParamSpec::new_uint(
|
||||||
|
"lateness",
|
||||||
|
"Lateness",
|
||||||
|
"Amount of milliseconds to introduce as lateness",
|
||||||
|
0,
|
||||||
|
std::u32::MAX,
|
||||||
|
DEFAULT_LATENESS.mseconds() as u32,
|
||||||
|
glib::ParamFlags::READWRITE | gst::PARAM_FLAG_MUTABLE_READY,
|
||||||
|
),
|
||||||
glib::ParamSpec::new_string(
|
glib::ParamSpec::new_string(
|
||||||
"vocabulary-name",
|
"vocabulary-name",
|
||||||
"Vocabulary Name",
|
"Vocabulary Name",
|
||||||
|
@ -1120,6 +1148,12 @@ impl ObjectImpl for Transcriber {
|
||||||
value.get::<u32>().expect("type checked upstream").into(),
|
value.get::<u32>().expect("type checked upstream").into(),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
"lateness" => {
|
||||||
|
let mut settings = self.settings.lock().unwrap();
|
||||||
|
settings.lateness = gst::ClockTime::from_mseconds(
|
||||||
|
value.get::<u32>().expect("type checked upstream").into(),
|
||||||
|
);
|
||||||
|
}
|
||||||
"vocabulary-name" => {
|
"vocabulary-name" => {
|
||||||
let mut settings = self.settings.lock().unwrap();
|
let mut settings = self.settings.lock().unwrap();
|
||||||
settings.vocabulary = value.get().expect("type checked upstream");
|
settings.vocabulary = value.get().expect("type checked upstream");
|
||||||
|
@ -1148,6 +1182,10 @@ impl ObjectImpl for Transcriber {
|
||||||
let settings = self.settings.lock().unwrap();
|
let settings = self.settings.lock().unwrap();
|
||||||
(settings.latency.mseconds() as u32).to_value()
|
(settings.latency.mseconds() as u32).to_value()
|
||||||
}
|
}
|
||||||
|
"lateness" => {
|
||||||
|
let settings = self.settings.lock().unwrap();
|
||||||
|
(settings.lateness.mseconds() as u32).to_value()
|
||||||
|
}
|
||||||
"vocabulary-name" => {
|
"vocabulary-name" => {
|
||||||
let settings = self.settings.lock().unwrap();
|
let settings = self.settings.lock().unwrap();
|
||||||
settings.vocabulary.to_value()
|
settings.vocabulary.to_value()
|
||||||
|
|
Loading…
Reference in a new issue