Skip to main content

nominal_api/conjure/objects/scout/compute/api/
rolling_time_aggregation_builder.rs

1/// Rolling time-window aggregation: for each point in the input, aggregate the values within the preceding
2/// time window.
3#[derive(
4    Debug,
5    Clone,
6    conjure_object::serde::Serialize,
7    conjure_object::serde::Deserialize,
8    conjure_object::private::DeriveWith
9)]
10#[serde(crate = "conjure_object::serde")]
11#[derive_with(PartialEq, Eq, PartialOrd, Ord, Hash)]
12#[conjure_object::private::staged_builder::staged_builder]
13#[builder(crate = conjure_object::private::staged_builder, update, inline)]
14pub struct RollingTimeAggregationBuilder {
15    #[builder(custom(type = super::Series, convert = Box::new))]
16    #[serde(rename = "input")]
17    input: Box<super::Series>,
18    #[builder(custom(type = super::Duration, convert = Box::new))]
19    #[serde(rename = "window")]
20    window: Box<super::Duration>,
21}
22impl RollingTimeAggregationBuilder {
23    /// Constructs a new instance of the type.
24    #[inline]
25    pub fn new(input: super::Series, window: super::Duration) -> Self {
26        Self::builder().input(input).window(window).build()
27    }
28    #[inline]
29    pub fn input(&self) -> &super::Series {
30        &*self.input
31    }
32    #[inline]
33    pub fn window(&self) -> &super::Duration {
34        &*self.window
35    }
36}