pub struct Streams {
pub timestamps: Vec<f64>,
pub channels: Vec<Stream>,
}Expand description
Time-series data associated with a workout.
Design: Strava-style columnar layout. All arrays are index-aligned —
timestamps[i] and every channels[j].data[i] refer to the same
moment in time.
TIME AXIS ──────────────────────────────────────────────▶
timestamps: [0, 5, 10, 15, 20, ...]
channels:
HeartRate(Scalar): [85, 125, 130, 129, 128, ...]
Speed(Scalar): [0, 2.5, 2.7, 2.8, 2.9, ...]
GPS(Position): [{51.5,-0.1}, {51.5,-0.1}, ...]This is separate from the Node tree intentionally. The tree describes structure (exercises, sets, blocks). Streams describe continuous sensor recordings over time. They are connected by time offsets, not by parent-child nesting.
Fields§
§timestamps: Vec<f64>Seconds from workout start for each sample index. Monotonically increasing. Length defines the shared array size.
channels: Vec<Stream>Sensor data channels, all index-aligned with timestamps.
Implementations§
Source§impl Streams
impl Streams
Sourcepub fn validate(&self) -> Result<(), StreamValidationError>
pub fn validate(&self) -> Result<(), StreamValidationError>
Validate structural invariants: all channel data arrays must have
the same length as timestamps.
Does NOT check semantic invariants (monotonic timestamps, valid lat/lng ranges, NaN values). Semantic validation is app-level.
Trait Implementations§
Source§impl<'de> Deserialize<'de> for Streams
impl<'de> Deserialize<'de> for Streams
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl TS for Streams
impl TS for Streams
Source§type WithoutGenerics = Streams
type WithoutGenerics = Streams
WithoutGenerics should just be Self.
If the type does have generic parameters, then all generic parameters must be replaced with
a dummy type, e.g ts_rs::Dummy or (). The only requirement for these dummy types is that
EXPORT_TO must be None. Read moreSource§type OptionInnerType = Streams
type OptionInnerType = Streams
std::option::Option<T>, then this associated type is set to T.
All other implementations of TS should set this type to Self instead.Source§fn docs() -> Option<String>
fn docs() -> Option<String>
TS is derived, docs are
automatically read from your doc comments or #[doc = ".."] attributesSource§fn decl_concrete(cfg: &Config) -> String
fn decl_concrete(cfg: &Config) -> String
TS::decl().
If this type is not generic, then this function is equivalent to TS::decl().Source§fn decl(cfg: &Config) -> String
fn decl(cfg: &Config) -> String
type User = { user_id: number, ... }.
This function will panic if the type has no declaration. Read moreSource§fn inline(cfg: &Config) -> String
fn inline(cfg: &Config) -> String
{ user_id: number }.
This function will panic if the type cannot be inlined.Source§fn inline_flattened(cfg: &Config) -> String
fn inline_flattened(cfg: &Config) -> String
Source§fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
Source§fn output_path() -> Option<PathBuf>
fn output_path() -> Option<PathBuf>
T should be exported, relative to the output directory.
The returned path does not include any base directory. Read moreSource§fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
Source§fn dependencies(cfg: &Config) -> Vec<Dependency>where
Self: 'static,
fn dependencies(cfg: &Config) -> Vec<Dependency>where
Self: 'static,
Source§fn export(cfg: &Config) -> Result<(), ExportError>where
Self: 'static,
fn export(cfg: &Config) -> Result<(), ExportError>where
Self: 'static,
TS::export_all. Read moreSource§fn export_all(cfg: &Config) -> Result<(), ExportError>where
Self: 'static,
fn export_all(cfg: &Config) -> Result<(), ExportError>where
Self: 'static,
TS::export. Read more