pub struct Measurement {
pub tracker: String,
pub epoch: Epoch,
pub data: IndexMap<MeasurementType, f64>,
pub rejected: bool,
}Expand description
A type-agnostic simultaneous measurement storage structure. Allows storing any number of simultaneous measurement of a given taker.
Note that two measurements are considered equal if the tracker and epoch match exactly, and if both have the same measurement types, and those measurements are equal to within 1e-10 (this allows for some leeway in TDM producers).
Fields§
§tracker: StringTracker alias which made this measurement
epoch: EpochEpoch of the measurement
data: IndexMap<MeasurementType, f64>All measurements made simultaneously
rejected: boolWhether this measurement has been manually rejected
Implementations§
Source§impl Measurement
impl Measurement
Sourcepub fn correct(&mut self, msr_type: MeasurementType, correction: f64)
pub fn correct(&mut self, msr_type: MeasurementType, correction: f64)
Correct the provided measurement type with the provided correction, if that measurement type is available
pub fn push(&mut self, msr_type: MeasurementType, msr_value: f64)
Source§impl Measurement
impl Measurement
pub fn new(tracker: String, epoch: Epoch) -> Self
pub fn with(self, msr_type: MeasurementType, msr_value: f64) -> Self
Sourcepub fn observation<S: DimName>(
&self,
types: &IndexSet<MeasurementType>,
) -> OVector<f64, S>where
DefaultAllocator: Allocator<S>,
pub fn observation<S: DimName>(
&self,
types: &IndexSet<MeasurementType>,
) -> OVector<f64, S>where
DefaultAllocator: Allocator<S>,
Builds an observation vector for this measurement provided a set of measurement types. If the requested measurement type is not available, then that specific row is set to zero. The caller must set the appropriate sensitivity matrix rows to zero.
Sourcepub fn availability(&self, types: &IndexSet<MeasurementType>) -> Vec<bool>
pub fn availability(&self, types: &IndexSet<MeasurementType>) -> Vec<bool>
Returns a vector specifying which measurement types are available.
Trait Implementations§
Source§impl Clone for Measurement
impl Clone for Measurement
Source§fn clone(&self) -> Measurement
fn clone(&self) -> Measurement
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for Measurement
impl Debug for Measurement
Source§impl Display for Measurement
impl Display for Measurement
Source§impl<'a, 'py> FromPyObject<'a, 'py> for Measurementwhere
Self: Clone,
impl<'a, 'py> FromPyObject<'a, 'py> for Measurementwhere
Self: Clone,
Source§impl<'py> IntoPyObject<'py> for Measurement
impl<'py> IntoPyObject<'py> for Measurement
Source§type Target = Measurement
type Target = Measurement
Source§type Output = Bound<'py, <Measurement as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <Measurement as IntoPyObject<'py>>::Target>
Source§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
Source§impl PartialEq for Measurement
impl PartialEq for Measurement
Source§impl PyClass for Measurement
impl PyClass for Measurement
Source§impl PyClassImpl for Measurement
impl PyClassImpl for Measurement
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
Source§const RAW_DOC: &'static CStr = /// A type-agnostic simultaneous measurement storage structure. Allows storing any number of simultaneous measurement of a given taker.
///
/// Note that two measurements are considered equal if the tracker and epoch match exactly, and if both have the same measurement types,
/// and those measurements are equal to within 1e-10 (this allows for some leeway in TDM producers).
const RAW_DOC: &'static CStr = /// A type-agnostic simultaneous measurement storage structure. Allows storing any number of simultaneous measurement of a given taker. /// /// Note that two measurements are considered equal if the tracker and epoch match exactly, and if both have the same measurement types, /// and those measurements are equal to within 1e-10 (this allows for some leeway in TDM producers).
Source§const DOC: &'static CStr
const DOC: &'static CStr
text_signature if a constructor is defined. Read moreSource§type Layout = <<Measurement as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<Measurement>
type Layout = <<Measurement as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<Measurement>
Source§type ThreadChecker = NoopThreadChecker
type ThreadChecker = NoopThreadChecker
type Inventory = Pyo3MethodsInventoryForMeasurement
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
PyAny by default, and when you declare
#[pyclass(extends=PyDict)], it’s PyDict.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
§fn dict_offset() -> Option<PyObjectOffset>
fn dict_offset() -> Option<PyObjectOffset>
§fn weaklist_offset() -> Option<PyObjectOffset>
fn weaklist_offset() -> Option<PyObjectOffset>
Source§impl PyClassNewTextSignature for Measurement
impl PyClassNewTextSignature for Measurement
const TEXT_SIGNATURE: &'static str = "(tracker, epoch)"
Source§impl PyTypeInfo for Measurement
impl PyTypeInfo for Measurement
Source§const NAME: &str = <Self as ::pyo3::PyClass>::NAME
const NAME: &str = <Self as ::pyo3::PyClass>::NAME
prefer using ::type_object(py).name() to get the correct runtime value
Source§const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE
const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE
prefer using ::type_object(py).module() to get the correct runtime value
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type or a subclass of this type.§fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type.impl DerefToPyAny for Measurement
Auto Trait Implementations§
impl Freeze for Measurement
impl RefUnwindSafe for Measurement
impl Send for Measurement
impl Sync for Measurement
impl Unpin for Measurement
impl UnsafeUnpin for Measurement
impl UnwindSafe for Measurement
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
self into an owned Python object, dropping type information.§fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
self into an owned Python object, dropping type information and unbinding it
from the 'py lifetime.§fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
self into a Python object. Read more§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
§const NAME: &'static str = T::NAME
const NAME: &'static str = T::NAME
Use ::classinfo_object() instead and format the type name at runtime. Note that using built-in cast features is often better than manual PyTypeCheck usage.
§fn type_check(object: &Bound<'_, PyAny>) -> bool
fn type_check(object: &Bound<'_, PyAny>) -> bool
§fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
isinstance and issubclass function. Read more§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.